本文介绍创建时空数据表的语法。
语法
create_table_statement ::= CREATE TABLE [ IF NOT EXISTS ] table_name
'('
column_definition
( ',' column_definition )*
',' [constraint pk] PRIMARY KEY '(' primary_key ')'
')' WITH [ table_options ]
column_definition ::= column_name lql_type
primary_key ::= primary_item [ ',' primary_item ]
primary_item ::= column_name (ASC|DESC)
| [z-order] '(' [ column_name ( ',' column_name )* ] ')'
创建表语句支持IF NOT EXISTS,其中主键由某个或某几个列组合而成。
使用说明
表名(table_identifier)
关于表名的设置,您需要注意以下内容:
可包含数字、大写英文字符、小写英文字符、半角句号(.)、中划线(-)和下划线(_)。
表名不能以半角句号(.)或中划线(-)开头。
表名的长度为1~255字符。
列定义(column_definition)
语法要素 | 是否必填 | 使用说明 |
列名(column_identifier) | 是 |
|
数据类型(data_type) | 是 | 支持的数据类型,请参见数据类型。 重要 创建时序表时,如果需要使用时间戳(TIMESTAMP)数据类型,请注意以下几点:
|
NULL约束 | 否 | 列的值是否允许为NULL。 重要 目前Lindorm SQL不会进行NULL约束的校验,该校验工作是由存储引擎执行的。 NULL约束的校验方式取决于存储引擎的校验规则,不同存储引擎的校验规则不同,因此在使用过程中可能会出现已指定NOT NULL但仍可写入NULL的情况。 为保证数据能够正常写入,请遵循以下统一要求:
|
主键(primary_key)
Lindorm单机版实例不支持PRIMARY KEY。
主键是表中数据的唯一标识,由一列或多列组成,建表时必须指定主键PRIMARY KEY。
在使用CREATE TABLE
语句建表时,需要注意以下内容:
引擎类型 | 主键使用说明 |
宽表引擎 |
|
时序引擎 |
|
分区(partition_definition)
仅时序引擎支持分区。在时序表中,用作PARTITION BY的列必须是主键定义中的VARCHAR列。
建表时,您可以通过PARTITION BY HASH(column1, column2, ..., columnN)
语句,显示指定一个或多个列为表进行Hash分区。例如:PARTITION BY HASH(c1, p1)
。
表属性(table_options)
仅宽表引擎支持表属性(table_options)。您可以通过WITH
关键字添加以下表属性:
选项 | 类型 | 描述 |
COMPRESSION | STRING | 表的压缩算法。可选的压缩算法分别是:
说明 宽表引擎2.3.4版本前默认未指定压缩算法,宽表引擎2.3.4及以后的版本默认压缩算法为ZSTD。 |
TTL | INT | 数据有效期,单位为秒(s)。 说明
|
COMPACTION_MAJOR_PERIOD | LONG | 系统执行 说明 默认值:Math.Min(TTL,1728000000ms)。如果不设置TTL,系统默认该参数值为20天(20*24*60*60*1000ms=1728000000ms)。 |
MUTABILITY | STRING | 索引相关,表示对主表的写入模式进行分类。默认值为MUTABLE_LATEST。 所有取值如下:
取值的详细说明,请参见高性能原生二级索引。 重要 创建索引表后,MUTABILITY参数的值不支持修改。 |
CONSISTENCY | STRING | 表的一致性属性。对于多可用区实例,该参数表示主备数据的一致性。包括以下两种级别:
重要 对于多可用区实例,如果数据存在先读后写,例如increase、append、索引更新,则需要指定主表CONSISTENCY参数的值为 |
NUMREGIONS | INT | 预先设置建表时的Region数。 |
CHS | INT | 冷热分界线,单位为秒。 说明
|
STARTKEY和ENDKEY | 与PRIMARY KEY中第一个列的数据类型相同 | 预先设置建表的Region分区起止Key。 说明
|
SPLITKEYS | 与PRIMARY KEY中第一个列的数据类型相同 | 预先设置表的全部预分区的起始Key。 说明
|
SPLITALGO | STRING | 定义预分区的分裂算法。目前仅支持以下分裂算法:
|
DYNAMIC_COLUMNS | STRING | 是否开启动态列。取值:
说明 动态列仅支持Varbinary类型。关于动态列的介绍,请参见动态列。 |
VERSIONS | STRING | 列值保留的版本数。取值为大于等于1的整数。默认值为1,表示保留一个版本。Lindorm支持列值保留多个版本,多版本管理的详细说明,请参见多版本数据管理。 重要 VERSIONS参数的值过大可能会影响数据的查询和存储性能,请尽量避免设置过大的值。建议将VERSIONS的值设置1。 |
BLOB_BUCKET_NAME | STRING | 为包含BLOB列的表创建BUCKET。取值为自定义的BUCKET名称。 BUCKET名称需遵循以下规则:
说明
|
2.2.16版本前的宽表引擎在设置表属性时不支持WITH
关键字,需在表属性关键字前后添加半角单引号('),属性值可以基于类型进行设置。如果属性值的类型是字符串(STRING)则需在字符串前后添加半角单引号('),例如CREATE TABLE IF NOT EXISTS t1(c1 varchar, c2 bigint, c3 int, c4 int, PRIMARY KEY(c1,c2)) 'CONSISTENCY'='strong';
。
示例
创建支持任意空间数据类型(Geometry)的表,可以写入任意空间数据类型。
CREATE TABLE geoms(gid INT, g GEOMETRY, PRIMARY KEY(gid));
写入任意空间数据类型的数据。
UPSERT INTO geoms(gid, g) VALUES(0,ST_GeomFromText('POINT(-10.1 3.3)')),(1,ST_GeomFromText('LINESTRING(-12.2 4.3, -10.2 4.3)')),(2,ST_GeomFromText('POLYGON((2 2, 2 8, 8 8, 8 2, 2 2))'));
创建支持点类型(Point)的表,仅支持写入点数据。
CREATE TABLE pts(gid INT, g GEOMETRY(POINT), PRIMARY KEY(gid));
写入点数据。
UPSERT INTO pts(gid, g) VALUES(0, ST_MakePoint(0,0)),(1, ST_MakePoint(1,1));
创建支持面类型(Polygon)的表,仅支持写入面数据。
CREATE TABLE polys(gid INT, g GEOMETRY(POLYGON), PRIMARY KEY(gid));
写入面数据。
UPSERT INTO polys(gid,g) VALUES(0,ST_GeomFromText('POLYGON((2 2, 2 8, 8 8, 8 2, 2 2))'));
创建支持线类型(LineString)的表,仅支持写入线数据。
CREATE TABLE lines(gid INT, g GEOMETRY(LINESTRING), PRIMARY KEY(gid));
写入线数据。
UPSERT INTO lines(gid,g) VALUES(0, ST_GeomFromText('LINESTRING(-12.2 4.3, -10.2 4.3)'));
创建支持多点(MULTIPOINT)类型的表,仅支持写入多点数据。
CREATE TABLE multipoints(gid INT, g GEOMETRY(MULTIPOINT), PRIMARY KEY(gid));
写入多点数据。
UPSERT INTO multipoints(gid,g) VALUES(0, ST_GeomFromText('MULTIPOINT (10 40, 40 30, 20 20, 30 10)'));
创建支持多线段(MULTILINESTRING)类型的表,仅支持写入多线段数据。
CREATE TABLE multilines(gid INT, g GEOMETRY(MULTILINESTRING), PRIMARY KEY(gid));
写入多线段数据。
UPSERT INTO multilines(gid,g) VALUES(0, ST_GeomFromText('MULTILINESTRING ((10 10, 20 20, 10 40),(40 40, 30 30, 40 20, 30 10))'));
创建支持多面(MULTIPOLYGON)类型的表,仅支持写入多面数据。
CREATE TABLE multipolys(gid INT, g GEOMETRY(MULTIPOLYGON), PRIMARY KEY(gid));
写入多面数据。
UPSERT INTO multipolys(gid,g) VALUES(0, ST_GeomFromText('MULTIPOLYGON (((30 20, 45 40, 10 40, 30 20)),((15 5, 40 10, 10 20, 5 10, 15 5)))'));
创建支持多空间对象(GEOMETRYCOLLECTION)类型的表,仅支持写入多空间对象数据。
CREATE TABLE collections(gid INT, g GEOMETRY(GEOMETRYCOLLECTION), PRIMARY KEY(gid));
写入多空间对象数据。
UPSERT INTO collections(gid,g) VALUES(0, ST_GeomFromText('GEOMETRYCOLLECTION (POINT (40 10), LINESTRING (10 10, 20 20, 10 40), POLYGON ((40 40, 20 45, 45 30, 40 40)))'));
创建由多个空间数据类型(Geometry)的列组成的表。
CREATE TABLE mix(gid INT, pt GEOMETRY(POINT), ply GEOMETRY(POLYGON), PRIMARY KEY(gid));