CREATE SOURCE
A source is a resource that RisingWave can read data from. You can create a source in RisingWave using the CREATE SOURCE
command.
If you choose to persist the data from the source in RisingWave, use the CREATE TABLE
command with connector settings. Or if you need to create the primary key (which is required by some formats like FORMAT UPSERT/DEBEZIUM), you have to use CREATE TABLE
too. For more details, see CREATE TABLE.
Regardless of whether the data is persisted in RisingWave, you can create materialized views to perform analysis or data transformations.
Syntax
CREATE SOURCE [ IF NOT EXISTS ] source_name (
col_name data_type [ AS generation_expression ],
...
[ watermark_clause ]
)
[ WITH (
connector='connector_name',
connector_parameter='value', ...)]
[FORMAT data_format ENCODE data_encode [ (
message='message',
schema.location='location', ...) ]
];
Notes
A generated column is defined with non-deterministic functions. When the data is ingested, the function will be evaluated to generate the value of this field.
Names and unquoted identifiers are case-insensitive. Therefore, you must double-quote any of these fields for them to be case-sensitive.
To know when a data record is loaded to RisingWave, you can define a column that is generated based on the processing time (<column_name> timestamptz AS proctime()
) when creating the table or source.
Parameters
Parameter | Description |
---|---|
source_name | The name of the source. If a schema name is given (for example, CREATE SOURCE <schema>.<source> ... ), then the table is created in the specified schema. Otherwise it is created in the current schema. |
col_name | The name of a column. |
data_type | The data type of a column. With the struct data type, you can create a nested table. Elements in a nested table need to be enclosed with angle brackets (<> ). |
generation_expression | The expression for the generated column. For details about generated columns, see Generated columns. |
watermark_clause | A clause that defines the watermark for a timestamp column. The syntax is WATERMARK FOR column_name as expr . For details about watermarks, refer to Watermarks. |
WITH clause | Specify the connector settings here if trying to store all the source data. See Supported sources for the full list of supported source as well as links to specific connector pages detailing the syntax for each source. |
FORMAT and ENCODE options | Specify the data format and the encoding format of the source data. To learn about the supported data formats, see Supported formats. |
Supported sources
Click a connector name to see the SQL syntax, options, and sample statement of connecting RisingWave to the connector.
To ingest data in formats marked with "T", you need to create tables (with connector settings). Otherwise, you can create either sources or tables (with connector settings).
Connector | Version | Format |
---|---|---|
Kafka | 3.1.0 or later versions | Avro, JSON, protobuf, Debezium JSON (T), Debezium AVRO (T), DEBEZIUM_MONGO_JSON (T), Maxwell JSON (T), Canal JSON (T), Upsert JSON (T), Upsert AVRO (T), Bytes |
Redpanda | Latest | Avro, JSON, protobuf |
Pulsar | 2.8.0 or later versions | Avro, JSON, protobuf, Debezium JSON (T), Maxwell JSON (T), Canal JSON (T) |
Astra Streaming | Latest | Avro, JSON, protobuf |
Kinesis | Latest | Avro, JSON, protobuf, Debezium JSON (T), Maxwell JSON (T), Canal JSON (T) |
PostgreSQL CDC | 10, 11, 12, 13, 14 | Debezium JSON (T) |
MySQL CDC | 5.7, 8.0 | Debezium JSON (T) |
CDC via Kafka | Debezium JSON (T), Maxwell JSON (T), Canal JSON (T) | |
Amazon S3 | Latest | JSON, CSV |
Load generator | Built-in | JSON |
Google Pub/Sub | Avro, JSON, protobuf, Debezium JSON (T), Maxwell JSON (T), Canal JSON (T) | |
Google Cloud Storage | JSON |
When a source is created, RisingWave does not ingest data immediately. RisingWave starts to process data when a materialized view is created based on the source.
Watermarks
RisingWave supports generating watermarks when creating a source. Watermarks are like markers or signals that track the progress of event time, allowing you to process events within their corresponding time windows. The WATERMARK
clause should be used within the schema_definition
. For more information on how to create a watermark, see Watermarks.
Change Data Capture (CDC)
Change Data Capture (CDC) refers to the process of identifying and capturing data changes in a database, then delivering the changes to a downstream service in real time.
RisingWave provides native MySQL and PostgreSQL CDC connectors. With these CDC connectors, you can ingest CDC data from these databases directly, without setting up additional services like Kafka.
If Kafka is part of your technical stack, you can also use the Kafka connector in RisingWave to ingest CDC data in the form of Kafka topics from databases into RisingWave. You need to use a CDC tool such as Debezium connector for MySQL or Maxwell's daemon to convert CDC data into Kafka topics.
For complete step-to-step guides about ingesting MySQL and PostgreSQL data using both approaches, see Ingest data from MySQL and Ingest data from PostgreSQL.
Supported formats
When creating a source, specify the data and encoding formats in the FORMAT
and ENCODE
section of the CREATE SOURCE
or CREATE TABLE
statement.
Avro
For data in Avro format, you must specify a message and a schema file location. The schema file location can be an actual Web location that is in http://...
, https://...
, or S3://...
format. For Kafka data in Avro, instead of a schema file location, you can provide a Confluent Schema Registry that RisingWave can get the schema from. For more details about using Schema Registry for Kafka data, see Read schema from Schema Registry.
schema.registry
can accept multiple addresses. RisingWave will send requests to all URLs and return the first successful result.
Optionally, you can define a schema.registry.name.strategy
if schema.registry
is set. Accepted options include topic_name_strategy
, record_name_strategy
, and topic_record_name_strategy
. If either record_name_strategy
or topic_record_name_strategy
is used, the key.message
field must also be defined. For additional details on name strategy, see Subject name strategy.
schema.registry.name.strategy
is currently in Beta. Please contact us if you encounter any issues or have feedback.
Note that the timestamp displayed in RisingWave may be different from the upstream system as timezone information is lost in Avro serialization.
For Avro data, you cannot specify the schema in the schema_definition
section of a CREATE SOURCE
or CREATE TABLE
statement.
Syntax:
FORMAT PLAIN
ENCODE AVRO (
message = 'main_message',
schema.location = 'location' | schema.registry = 'schema_registry_url [, ...]',
[schema.registry.name.strategy = 'topic_name_strategy'],
[key.message = 'test_key']
)
Debezium AVRO
When creating a source from streams in with Debezium AVRO, the schema of the source does not need to be defined in the CREATE TABLE
statement as it can be inferred from the SCHEMA REGISTRY
. This means that the schema file location must be specified. The schema file location can be an actual Web location, which is in http://...
, https://...
, or S3://...
format, or a Confluent Schema Registry. For more details about using Schema Registry for Kafka data, see Read schema from Schema Registry.
schema.registry
can accept multiple addresses. RisingWave will send requests to all URLs and return the first successful result.
Optionally, you can define a schema.registry.name.strategy
if schema.registry
is set. Accepted options include topic_name_strategy
, record_name_strategy
, and topic_record_name_strategy
. If either record_name_strategy
or topic_record_name_strategy
is used, the key.message
field must also be defined. For additional details on name strategy, see Subject name strategy.
schema.registry.name.strategy
is currently in Beta. Please contact us if you encounter any issues or have feedback.
Syntax:
FORMAT DEBEZIUM
ENCODE AVRO (
message = 'main_message',
schema.location = 'location' | schema.registry = 'schema_registry_url [, ...]',
[schema.registry.name.strategy = 'topic_name_strategy'],
[key.message = 'test_key']
)
Upsert AVRO
When consuming data in AVRO from Kafka topics, the FORMAT
and ENCODE
sections need to be specified as UPSERT
and AVRO
respectively. RisingWave will be aware that the source message contains key fields as primary columns, as well as the Kafka message value field. If the value field of the message is not null, the row will be updated if the message key is not empty and already exists in the database table, or inserted if the message key is not empty but does not exist yet in the database table. If the value field is null, the row will be deleted.
schema.registry
can accept multiple addresses. RisingWave will send requests to all URLs and return the first successful result.
Optionally, you can define a schema.registry.name.strategy
if schema.registry
is set. Accepted options include topic_name_strategy
, record_name_strategy
, and topic_record_name_strategy
. If either record_name_strategy
or topic_record_name_strategy
is used, the key.message
field must also be defined. For additional details on name strategy, see Subject name strategy.
schema.registry.name.strategy
is currently in Beta. Please contact us if you encounter any issues or have feedback.
Syntax:
FORMAT UPSERT
ENCODE AVRO (
message = 'main_message',
schema.location = 'location' | schema.registry = 'schema_registry_url [, ...]',
[schema.registry.name.strategy = 'topic_name_strategy'],
[key.message = 'test_key']
)
JSON
RisingWave decodes JSON directly from external sources. When creating a source from streams in JSON, you can define the schema of the source within the parentheses after the source name or specify a schema.registry
. Specify the data and encoding formats in the FORMAT
and ENCODE
sections. You can directly reference data fields in the JSON payload by their names as column names in the schema.
schema.registry
can accept multiple addresses. RisingWave will send requests to all URLs and return the first successful result.
Syntax:
FORMAT PLAIN
ENCODE JSON [ (
schema.registry = 'schema_registry_url [, ...]',
[schema.registry.username = 'username'],
[schema.registry.password = 'password']
) ]
Canal JSON
RisingWave supports the TiCDC dialect of the Canal CDC format. When creating a source from streams in TiCDC, you can define the schema of the source within the parentheses after the source name (schema_definition
in the syntax), and specify the data and encoding formats in the FORMAT
and ENCODE
section. You can directly reference data fields in the JSON payload by their names as column names in the schema.
Syntax:
FORMAT CANAL
ENCODE JSON
Debezium JSON
When creating a source from streams in Debezium JSON, you can define the schema of the source within the parentheses after the source name (schema_definition
in the syntax), and specify the data and encoding formats in the FORMAT
and ENCODE
sections. You can directly reference data fields in the JSON payload by their names as column names in the schema.
Note that if you are ingesting data of type timestamp
or timestamptz
in RisingWave, the upstream value must be in the range of [1973-03-03 09:46:40, 5138-11-16 09:46:40] (UTC)
. The value may be parsed and ingested incorrectly without warning.
Syntax:
FORMAT DEBEZIUM
ENCODE JSON
Debezium Mongo JSON
When loading data from MongoDB via Kafka topics in Debezium Mongo JSON format, the source table schema has a few limitations. The table schema must have the columns _id
and payload
, where _id
comes from the MongoDB document's id
and is the primary key, and payload
is type jsonb
and contains the rest of the document. If the document's _id
is type ObjectID
, then when creating the column in RisingWave, specify the type of _id
as varchar
. If the document's _id
is of type int32
or int64
, specify the type of _id
as int
or bigint
in RisingWave.
Syntax:
FORMAT DEBEZIUM_MONGO
ENCODE JSON
Maxwell JSON
When creating a source from streams in Maxwell JSON, you can define the schema of the source within the parentheses after the source name (schema_definition
in the syntax), and specify the data and encoding formats in the FORMAT
and ENCODE
sections. You can directly reference data fields in the JSON payload by their names as column names in the schema.
Syntax:
FORMAT MAXWELL
ENCODE JSON
Upsert JSON
When consuming data in JSON from Kafka topics, the FORMAT
and ENCODE
sections need to be specified as UPSERT
and JSON
respectively. RisingWave will be aware that the source message contains key fields as primary columns, as well as the Kafka message value field. If the value field of the message is not null, the row will be updated if the message key is not empty and already exists in the database table, or inserted if the message key is not empty but does not exist yet in the database table. If the value field is null, the row will be deleted.
You can define the schema of the source within the parentheses after the source name or specify a schema.registry
. schema.registry
can accept multiple addresses. RisingWave will send requests to all URLs and return the first successful result.
Syntax:
FORMAT UPSERT
ENCODE JSON [ (
schema.registry = 'schema_registry_url [, ...]',
[schema.registry.username = 'username'],
[schema.registry.password = 'password']
) ]
Protobuf
For data in protobuf format, you must specify a message and a schema location. The schema location can be an actual Web location that is in http://...
, https://...
, or S3://...
format. For Kafka data in protobuf, instead of providing a schema location, you can provide a Confluent Schema Registry that RisingWave can get the schema from. For more details about using Schema Registry for Kafka data, see Read schema from Schema Registry.
schema.registry
can accept multiple addresses. RisingWave will send requests to all URLs and return the first successful result.
Optionally, you can define a schema.registry.name.strategy
if schema.registry
is set. Accepted options include topic_name_strategy
, record_name_strategy
, and topic_record_name_strategy
. If either record_name_strategy
or topic_record_name_strategy
is used, the key.message
field must also be defined. For additional details on name strategy, see Subject name strategy.
schema.registry.name.strategy
is currently in Beta. Please contact us if you encounter any issues or have feedback.
For protobuf data, you cannot specify the schema in the schema_definition
section of a CREATE SOURCE
or CREATE TABLE
statement.
If you provide a file location, the schema file must be a FileDescriptorSet
, which can be compiled from a .proto
file with a command like this:
protoc -I=$include_path --include_imports --descriptor_set_out=schema.pb schema.proto
Syntax:
FORMAT PLAIN
ENCODE PROTOBUF (
message = 'main_message',
schema.location = 'location' | schema.registry = 'schema_registry_url [, ...]',
[schema.registry.name.strategy = 'topic_name_strategy'],
[key.message = 'test_key']
)
For more information on supported protobuf types, refer to Supported protobuf types.
Bytes
RisingWave allows you to read data streams without decoding the data by using the BYTES
row format. However, the table or source can have exactly one field of BYTEA
data.
FORMAT PLAIN
ENCODE BYTES
See also
DROP SOURCE
— Remove a source.SHOW CREATE SOURCE
— Show the SQL statement used to create a source.