| title | MongoDB |
|---|---|
| description | Query MongoDB from Cube through the BI Connector’s SQL interface, including community-driver and Atlas deprecation caveats. |
MongoDB is a popular document database. It can be accessed using SQL via the MongoDB Connector for BI, also known as BI Connector.
The driver for MongoDB is community-supported and is not maintained by Cube or the database vendor.
BI Connector for MongoDB Atlas, cloud-based MongoDB service, is approaching end-of-life. It will be deprecated and no longer supported in June 2025.
To use Cube with MongoDB you need to install the MongoDB Connector for BI. Learn more about setup for MongoDB here.
- MongoDB Connector for BI
- The hostname for the MongoDB database server
- The username/password for the MongoDB database server
Add the following to a .env file in your Cube project:
CUBEJS_DB_TYPE=mongobi
# The MongoBI connector host. If using on local machine, it should be either `localhost` or `127.0.0.1`:
CUBEJS_DB_HOST=my.mongobi.host
# The default port of the MongoBI connector service
CUBEJS_DB_PORT=3307
CUBEJS_DB_NAME=my_mongodb_database
CUBEJS_DB_USER=mongodb_server_user
CUBEJS_DB_PASS=mongodb_server_password
# MongoBI requires SSL connections, so set the following to `true`:
CUBEJS_DB_SSL=trueIf you are connecting to a local MongoBI Connector, which is pointing to a local
MongoDB instance, If MongoBI Connector and MongoDB are both running locally,
then the above should work. To connect to a remote MongoDB instance, first
configure mongosqld appropriately. See here for an example config
file.
| Environment Variable | Description | Possible Values | Required |
|---|---|---|---|
CUBEJS_DB_HOST |
The host URL for a database | A valid database host URL | ✅ |
CUBEJS_DB_PORT |
The port for the database connection | A valid port number | ❌ |
CUBEJS_DB_NAME |
The name of the database to connect to | A valid database name | ✅ |
CUBEJS_DB_USER |
The username used to connect to the database | A valid database username | ✅ |
CUBEJS_DB_PASS |
The password used to connect to the database | A valid database password | ✅ |
CUBEJS_DB_SSL |
If true, enables SSL encryption for database connections from Cube |
true, false |
✅ |
CUBEJS_DB_MAX_POOL |
The maximum number of concurrent database connections to pool. Default is 8 |
A valid number | ❌ |
CUBEJS_CONCURRENCY |
The number of concurrent queries to the data source | A valid number | ❌ |
Measures of type
count_distinct_approx can
not be used in pre-aggregations when using MongoDB as a source database.
To learn more about pre-aggregation build strategies, head here.
| Feature | Works with read-only mode? | Is default? |
|---|---|---|
| Batching | ✅ | ✅ |
| Export Bucket | - | - |
By default, MongoDB uses batching to build pre-aggregations.
No extra configuration is required to configure batching for MongoDB.
MongoDB does not support export buckets.
To enable SSL-encrypted connections between Cube and MongoDB, set the
CUBEJS_DB_SSL environment variable to true. For more information on how to
configure custom certificates, please check out Enable SSL Connections to the
Database.