Documentation Index
Fetch the complete documentation index at: https://risingwavelabs-wyx-add-timestamp-dedicated-page.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Syntax
Parameters
| Parameter Name | Description |
|---|---|
| mongodb.url | The URL of MongoDB. |
| type | Defines the type of the sink. Options include append-only or upsert. |
| collection.name | The collection name where data should be written to or read from. For sinks, the format is db_name.collection_name. Data can also be written to dynamic collections, see collection.name.field below for more information. |
| collection.name.field | Optional. The dynamic collection name where data should be sunk to.
|
| collection.name.field.drop | Optional. Controls whether the field value of collection.name.field should be dropped when sinking. Set this option to true to avoid the duplicate values of collection.name.field being written to the result collection. |
Data type mapping
| MongoDB Type | RisingWave Type |
|---|---|
| Boolean | BOOLEAN |
| 32-bit integer | SMALLINT |
| 32-bit integer | INTEGER |
| 64-bit integer | BIGINT |
| Double | REAL |
| Double | DOUBLE |
| Decimal128 | DECIMAL |
| String | DATE |
| String | VARCHAR |
| String | TIME |
| Date | TIMESTAMP WITHOUT TIME ZONE |
| Date | TIMESTAMP WITH TIME ZONE |
| String | INTERVAL |
| Object | STRUCT |
| Array | ARRAY |
| Binary data | BYTEA |
| Object | JSONB |
| 64-bit integer | SERIAL |
Examples
Below are some use cases for your reference.Sink data with append-only
To create a sink with the append-only type:_id field for each record, typically with a value of the ObjectId type. This is necessary because _id is the primary key in MongoDB.
Sink data with upsert
To create a sink with the upsert type for a table with a single key:single key
t2 is:
| name | type | pk |
|---|---|---|
| id | int | ✔ |
| value | text |
| id | value |
|---|---|
| 1 | ’example of record’ |
No redundant
id field will exist if the primary key of t2 is _id.compound key
Dynamic collection name
Dynamic collection names are useful in certain scenarios. For example, a multi-tenant application may store its data using sharding, wheretenant_id is included as a prefix in the collection name, such as sharding_2024_01.tenant1_order. This approach offers more flexibility and enables efficient data organization and retrieval based on specific tenant requirements.
To use a dynamic collection name:
collection.name: Serve as a fallback collection name if the value ofcollection.name.fieldis empty or null. In this case, it defaults todemo.t2.collection.name.field: Specify the field used for the collection name. This field must be of typevarchar.collection.name.field.drop: When set totrue, it avoids duplicate values ofcollection.name.fieldin the result collection.