1 - ALTER TABLE
使用 ALTER TABLE
可以改变表的结构和参数 .
变更表结构
例如可以使用 ADD COLUMN
增加表的列 :
1
2
3
| -- create a table and add a column to it
CREATE TABLE `t`(a int, t timestamp NOT NULL, TIMESTAMP KEY(t)) ENGINE = Analytic;
ALTER TABLE `t` ADD COLUMN (b string);
|
变更后的表结构如下:
-- DESCRIBE TABLE `t`;
name type is_primary is_nullable is_tag
t timestamp true false false
tsid uint64 true false false
a int false true false
b string false true false
变更表参数
例如可以使用 MODIFY SETTING
修改表的参数 :
1
2
3
| -- create a table and add a column to it
CREATE TABLE `t`(a int, t timestamp NOT NULL, TIMESTAMP KEY(t)) ENGINE = Analytic;
ALTER TABLE `t` MODIFY SETTING write_buffer_size='300M';
|
上面的 SQL 用来更改 writer_buffer
大小,变更后的建表如下:
1
| CREATE TABLE `t` (`tsid` uint64 NOT NULL, `t` timestamp NOT NULL, `a` int, PRIMARY KEY(tsid,t), TIMESTAMP KEY(t)) ENGINE=Analytic WITH(arena_block_size='2097152', compaction_strategy='default', compression='ZSTD', enable_ttl='true', num_rows_per_row_group='8192', segment_duration='', storage_format='AUTO', ttl='7d', update_mode='OVERWRITE', write_buffer_size='314572800')
|
除此之外,我们可以修改其 ttl
为 10 天:
1
| ALTER TABLE `t` MODIFY SETTING ttl='10d';
|
2 - DROP TABLE
基础语法
删除表的基础语法如下:
1
| DROP TABLE [IF EXISTS] table_name
|
Drop Table
用来删除一个表,请谨慎使用这个语句,因为会同时删除表的定义和表的数据,并且无法恢复。
3 - 创建表
基础语法
建表的基础语法如下 ( []
之间的内容是可选部分):
1
2
3
4
| CREATE TABLE [IF NOT EXISTS]
table_name ( column_definitions )
ENGINE = engine_type
[WITH ( table_options )];
|
列定义的语法 :
1
| column_name column_type [[NOT] NULL] {[TAG] | [TIMESTAMP KEY] | [PRIMARY KEY]} [DICTIONARY] [COMMENT '']
|
表选项的语法是键-值对,值用单引号('
)来引用。例如:
1
| ... WITH ( enable_ttl='false' )
|
IF NOT EXISTS
添加 IF NOT EXISTS
时,HoraeDB 在表名已经存在时会忽略建表错误。
定义列
一个列的定义至少应该包含名称和类型部分,支持的类型见 这里。
列默认为可空,即 “NULL " 关键字是隐含的;添加 NOT NULL
时列不可为空。
1
2
3
4
5
6
7
| -- this definition
a_nullable int
-- equals to
a_nullable int NULL
-- add NOT NULL to make it required
b_not_null NOT NULL
|
定义列时可以使用相关的关键字将列标记为 特殊列。
对于 string 的 tag 列,推荐设置为字典类型来减少内存占用:
1
| `tag1` string TAG DICTIONARY
|
引擎设置
HoraeDB 支持指定某个表使用哪种引擎,目前支持的引擎类型为 Analytic
。注意这个属性设置后不可更改。
分区设置
仅适用于集群部署模式
CREATE TABLE ... PARTITION BY KEY
下面这个例子创建了一个具有 8 个分区的表,分区键为 name
:
1
2
3
4
5
6
7
8
9
10
11
| CREATE TABLE `demo` (
`name` string TAG COMMENT 'client username',
`value` double NOT NULL,
`t` timestamp NOT NULL,
timestamp KEY (t)
)
PARTITION BY KEY(name) PARTITIONS 8
ENGINE=Analytic
with (
enable_ttl='false'
)
|