40c911597b
* feat: improve keywords definations and add prefix named KW_ * test: capitalize keywords in alter sql test cases * test: capitalize keywords in create sql test cases * feat: merge interval rule and timeIntervalExpression rule in flinksql grammar * test: put keywords in quotation marks around insert sql test cases * test: put keywords in quotation marks around select sql test cases * feat: improve uid rule * test: rename sum to _sum because it is a reserved keyword * docs: improve comments in flinkSqlLexer
234 lines
6.2 KiB
SQL
234 lines
6.2 KiB
SQL
CREATE TABLE MyTable ('user_id' BIGINT, 'name' STRING) WITH ('connector' = 'oracle-x');
|
|
|
|
CREATE TABLE MyTable WITH ('connector' = 'oracle-x');
|
|
|
|
-- 尽管官方文档的 BNF 里没有支持创建临时表,但实际上是支持的
|
|
CREATE TEMPORARY TABLE MyTable ('user_id' BIGINT, 'name' STRING) WITH ('connector' = 'oracle-x');
|
|
|
|
CREATE TABLE MyTable (
|
|
'user_id' BIGINT,
|
|
'name' STRING,
|
|
'timestamp' BIGINT METADATA, -- part of the query-to-sink schema
|
|
'offset' BIGINT METADATA VIRTUAL, -- not part of the query-to-sink schema
|
|
'record_time' TIMESTAMP(3) WITH LOCAL TIME ZONE METADATA FROM 'timestamp' -- reads and writes a Kafka record's timestamp
|
|
) WITH ('connector' = 'kafka');
|
|
|
|
CREATE TABLE MyTable (
|
|
'user_id' BIGINT,
|
|
'price' DOUBLE,
|
|
'quantity' DOUBLE,
|
|
'cost' AS price * quanitity -- evaluate expression and supply the result to queries
|
|
) WITH ('connector' = 'kafka');
|
|
|
|
CREATE TABLE MyTable (
|
|
'user' BIGINT,
|
|
product STRING,
|
|
order_time TIMESTAMP(3),
|
|
WATERMARK FOR order_time AS order_time - INTERVAL '5' SECOND
|
|
) WITH ('connector' = 'kafka');
|
|
|
|
CREATE TABLE MyTable (id INT, PRIMARY KEY (id) NOT ENFORCED) WITH ('connector' = 'kafka');
|
|
|
|
CREATE TABLE tbl1 (
|
|
a BIGINT,
|
|
h VARCHAR,
|
|
g AS 2 * (a + 1),
|
|
ts AS toTimestamp(b, 'yyyy-MM-dd HH:mm:ss'),
|
|
b VARCHAR,
|
|
proc AS PROCTIME(),
|
|
meta STRING METADATA,
|
|
my_meta STRING METADATA FROM 'meta',
|
|
my_meta STRING METADATA FROM 'meta' VIRTUAL,
|
|
meta STRING METADATA VIRTUAL,
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) PARTITIONED BY (a, h) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE Orders_in_file (
|
|
'user' BIGINT,
|
|
product STRING,
|
|
order_time_string STRING,
|
|
order_time AS to_timestamp(order_time)
|
|
) PARTITIONED BY ('user') WITH (
|
|
'connector' = 'filesystem',
|
|
'path' = '...'
|
|
);
|
|
|
|
CREATE TABLE Orders_with_watermark (
|
|
id INT,
|
|
-- Add watermark definition
|
|
WATERMARK FOR order_time AS order_time - INTERVAL '5' SECOND
|
|
) WITH (
|
|
-- Overwrite the startup-mode
|
|
'scan.startup.mode' = 'latest-offset'
|
|
) LIKE Orders_in_file (
|
|
-- Exclude everything besides the computed columns which we need to generate the watermark for.
|
|
-- We do not want to have the partitions or filesystem options as those do not apply to kafka.
|
|
EXCLUDING ALL
|
|
INCLUDING GENERATED
|
|
);
|
|
|
|
CREATE TABLE my_ctas_table WITH ('connector' = 'kafka')
|
|
AS SELECT
|
|
id,
|
|
name,
|
|
age
|
|
FROM
|
|
source_table
|
|
WHERE
|
|
mod(id, 10) = 0;
|
|
|
|
CREATE TABLE catalog1.db1.table1 (id INT) WITH ('connector' = 'kafka');
|
|
|
|
CREATE TABLE catalog1.db1.table1 (
|
|
attr0 STRING,
|
|
attr1 BOOLEAN,
|
|
attr3 DECIMAL(38, 18),
|
|
attr4 TINYINT,
|
|
attr5 SMALLINT,
|
|
attr6 INT,
|
|
attr7 BIGINT,
|
|
attr8 FLOAT,
|
|
attr9 DOUBLE,
|
|
attr10 DATE,
|
|
attr11 TIME,
|
|
attr12 TIMESTAMP(3),
|
|
attr13 ARRAY<STRING>,
|
|
attr14 ROW<attr15 FLOAT, attr16 TIMESTAMP(3)>,
|
|
attr17 MAP<INT, BIGINT>,
|
|
name1 VARCHAR(64),
|
|
message ROW<data ROW<UPO_TIMESTAMP VARCHAR(20)>>,
|
|
raw RAW('class', 'snapshot')
|
|
) WITH ('connector' = 'kafka');
|
|
|
|
CREATE TABLE IF NOT EXISTS tbl1 (
|
|
a BIGINT,
|
|
h VARCHAR,
|
|
g AS 2 * (a + 1),
|
|
ts AS toTimestamp(b, 'yyyy-MM-dd HH:mm:ss'),
|
|
b VARCHAR,
|
|
proc AS PROCTIME(),
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) PARTITIONED BY (a, h) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
a BIGINT COMMENT 'test column comment AAA.',
|
|
h VARCHAR,
|
|
g AS 2 * (a + 1),
|
|
ts AS toTimestamp(b, 'yyyy-MM-dd HH:mm:ss'),
|
|
b VARCHAR,
|
|
proc AS PROCTIME(),
|
|
meta STRING METADATA,
|
|
my_meta STRING METADATA FROM 'meta',
|
|
my_meta STRING METADATA FROM 'meta' VIRTUAL,
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) COMMENT 'test table comment ABC.' PARTITIONED BY (a, h) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
a BIGINT COMMENT 'test column comment AAA.',
|
|
h VARCHAR,
|
|
g AS 2 * (a + 1) COMMENT 'test computed column.',
|
|
ts AS toTimestamp(b, 'yyyy-MM-dd HH:mm:ss'),
|
|
b VARCHAR,
|
|
proc AS PROCTIME(),
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) COMMENT 'test table comment ABC.' PARTITIONED BY (a, h) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
a BIGINT,
|
|
h VARCHAR,
|
|
g AS 2 * (a + 1),
|
|
ts AS toTimestamp(b, 'yyyy-MM-dd HH:mm:ss'),
|
|
b VARCHAR,
|
|
proc AS PROCTIME(),
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
a BIGINT PRIMARY KEY NOT ENFORCED COMMENT 'test column comment AAA.',
|
|
h VARCHAR CONSTRAINT ct1 PRIMARY KEY NOT ENFORCED,
|
|
g AS 2 * (a + 1),
|
|
ts AS toTimestamp(b, 'yyyy-MM-dd HH:mm:ss'),
|
|
proc AS PROCTIME()
|
|
) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
ts TIMESTAMP(3),
|
|
id VARCHAR,
|
|
WATERMARK FOR ts AS ts - INTERVAL '3' SECOND
|
|
) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
log_ts VARCHAR,
|
|
ts AS to_timestamp(log_ts),
|
|
WATERMARK FOR ts AS ts + INTERVAL '1' SECOND
|
|
) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
f1 ROW<q1 BIGINT, q2 ROW<t1 TIMESTAMP, t2 VARCHAR>, q3 BOOLEAN>,
|
|
WATERMARK FOR f1.q2.t1 AS NOW()
|
|
) WITH (
|
|
'connector' = 'kafka',
|
|
'kafka.topic' = 'log.test'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
a ARRAY<BIGINT>,
|
|
b MAP<INT, VARCHAR>,
|
|
c ROW<cc0 INT, cc1 FLOAT, cc2 VARCHAR>,
|
|
d MULTISET<VARCHAR>,
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) WITH (
|
|
'x' = 'y',
|
|
'asd' = 'data'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
a ARRAY<ARRAY<BIGINT>>,
|
|
b MAP<MAP<INT, VARCHAR>, ARRAY<VARCHAR>>,
|
|
c ROW<cc0 ARRAY<INT>, cc1 FLOAT, cc2 VARCHAR>,
|
|
d MULTISET<ARRAY<INT>>,
|
|
f TIMESTAMP(9),
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) WITH (
|
|
'x' = 'y',
|
|
'asd' = 'data'
|
|
);
|
|
|
|
CREATE TABLE tbl1 (
|
|
a ARRAY<ARRAY<BIGINT>>,
|
|
b MAP<MAP<INT, VARCHAR>, ARRAY<VARCHAR>>,
|
|
c ROW<cc0 ARRAY<INT>, cc1 FLOAT, cc2 VARCHAR>,
|
|
d MULTISET<ARRAY<INT>>,
|
|
f TIMESTAMP(9),
|
|
PRIMARY KEY (a, b) NOT ENFORCED
|
|
) WITH (
|
|
'x' = 'y',
|
|
'asd' = 'data'
|
|
) LIKE Orders (
|
|
OVERWRITING OPTIONS
|
|
EXCLUDING CONSTRAINTS
|
|
); |