全局序列在INSERT或REPLACE语句中的使用
要想在同一个实例下实现跨逻辑库序列的全局唯一,可以在insert语句或者replace语句中结合全局序列一起使用。Insert语句和replace语句支持nextval和currval两个方式序列的获取。其中,nextval表示返回下一个序列值,currval表示返回当前序列值。
可以通过schema.seq.nextval、schema.seq.currval使用,如果不指定schema,默认是当前连接schema下的全局序列。
支持并发获取全局序列,在多session下并发通过schema.seq.nextval获取全局序列能够产生唯一值。
用法举例
两个逻辑库dml_test_1、dml_test_2,里面都有表test_seq。
表定义
表定义方法:create table test_seq(col1 bigint,col2 bigint) dbpartition by hash(col1)。
操作步骤
- 使用客户端连接DDM实例。
- 连接成功后,打开目标逻辑库。
- 在库级别下,输入命令创建全局序列。
use dml_test_1;
create sequence seq_test;
- 使用以下语句,实现全局序列在insert语句或者replace语句的使用。
- use dml_test_1;
insert into test_seq(col1,col2)values(seq_test.nextval,seq_test.currval);
- use dml_test_2;
insert into test_seq(col1,col2)values(dml_test_1.seq_test.nextval,dml_test_1.seq_test.currval);
由于全局序列是创建在逻辑库dml_test_1下的,在逻辑库dml_test_2下使用全局序列需要显式指定逻辑库dml_test_1.seq_test.nextval、dml_test_1.seq_test.currval。
- 全局序列结合insert和replace的使用只支持拆分表,不支持广播表和单表。
- nextval和currval在insert和replace语句中是从左到右执行的,如果一条语句使用同一个全局序列nextval多次,每出现一次就递增一次。
- 全局序列是属于逻辑库的,删除逻辑库,所在删除逻辑库的全局序列也会被删除。