CREATE TABLE
Synopsis¶
| 1 2 |  | 
Description¶
Create a new table with the specified columns and properties. Columns can be any of the data types supported by ksqlDB.
ksqlDB adds the implicit columns ROWTIME and ROWKEY to every stream
and table, which represent the corresponding Kafka message timestamp and
message key, respectively. The timestamp has milliseconds accuracy.
The WITH clause supports the following properties:
| Property | Description | 
|---|---|
| KAFKA_TOPIC (required) | The name of the Kafka topic that backs this source. The topic must either already exist in Kafka, or PARTITIONS must be specified to create the topic. Command will fail if the topic exists with different partition/replica counts. | 
| VALUE_FORMAT (required) | Specifies the serialization format of message values in the topic. Supported formats: JSON,JSON_SR,DELIMITED(comma-separated value),AVRO,KAFKA, andPROTOBUF. For more information, see Serialization Formats. | 
| PARTITIONS | The number of partitions in the backing topic. This property must be set if creating a TABLE without an existing topic (the command will fail if the topic does not exist). | 
| REPLICAS | The number of replicas in the backing topic. If this property is not set but PARTITIONS is set, then the default Kafka cluster configuration for replicas will be used for creating a new topic. | 
| VALUE_DELIMITER | Used when VALUE_FORMAT='DELIMITED'. Supports single character to be a delimiter, defaults to ','. For space and tab delimited values you must use the special values 'SPACE' or 'TAB', not an actual space or tab character. | 
| KEY | Optimization hint: If the Kafka message key is also present as a field/column in the Kafka message value, you may set this property to associate the corresponding field/column with the implicit ROWKEYcolumn (message key). If set, ksqlDB uses it as an optimization hint to determine if repartitioning can be avoided when performing aggregations and joins. You can only use this if the key format in kafka isVARCHARorSTRING. Do not use this hint if the message key format in kafka isAVROorJSON. For more information, see Key Requirements. | 
| TIMESTAMP | By default, the implicit ROWTIMEcolumn is the timestamp of the message in the Kafka topic. The TIMESTAMP property can be used to overrideROWTIMEwith the contents of the specified field/column within the Kafka message value (similar to timestamp extractors in the Kafka Streams API). Timestamps have a millisecond accuracy. Time-based operations, such as windowing, will process a record according to the timestamp inROWTIME. | 
| TIMESTAMP_FORMAT | Used in conjunction with TIMESTAMP. If not set will assume that the timestamp field is a bigint. If it is set, then the TIMESTAMP field must be of type varchar and have a format that can be parsed with the JavaDateTimeFormatter. If your timestamp format has characters requiring single quotes, you can escape them with two successive single quotes,'', for example:'yyyy-MM-dd''T''HH:mm:ssX'. For more information on timestamp formats, see DateTimeFormatter. | 
| WRAP_SINGLE_VALUE | Controls how values are deserialized where the values schema contains only a single field. The setting controls how ksqlDB will deserialize the value of the records in the supplied KAFKA_TOPICthat contain only a single field.If set to true, ksqlDB expects the field to have been serialized as named field within a record.If set to false, ksqlDB expects the field to have been serialized as an anonymous value.If not supplied, the system default, defined by ksql.persistence.wrap.single.values and defaulting to true, is used.Note: nullvalues have special meaning in ksqlDB. Care should be taken when dealing with single-field schemas where the value can benull. For more information, see Single field (un)wrapping.Note: Supplying this property for formats that do not support wrapping, for example DELIMITED, or when the value schema has multiple fields, will result in an error. | 
| WINDOW_TYPE | By default, the topic is assumed to contain non-windowed data. If the data is windowed, i.e. was created using ksqlDB using a query that contains a WINDOWclause, then theWINDOW_TYPEproperty can be used to provide the window type. Valid values areSESSION,HOPPING, andTUMBLING. | 
| WINDOW_SIZE | By default, the topic is assumed to contain non-windowed data. If the data is windowed, i.e., was created using ksqlDB using a query that contains a WINDOWclause, and theWINDOW_TYPEproperty is TUMBLING or HOPPING, then the WINDOW_SIZE property should be set. The property is a string with two literals, window size (a number) and window size unit (a time unit). For example:10 SECONDS. | 
Note
- To use Avro or Protobuf, you must have Schema Registry enabled and
ksql.schema.registry.urlmust be set in the ksqlDB server configuration file. See Configure ksqlDB for Avro or Protobuf.
- Avro and Protobuf field names are not case sensitive in ksqlDB. This matches the ksqlDB column name behavior.
Example¶
| 1 2 3 |  | 
Page last revised on: 2020-05-06
  
    
      Last update:
      2020-05-06