mycat全局序列号

mycat安装

本地文件方式

sequence_conf.properties

GLOBAL_SEQ.HISIDS=
GLOBAL_SEQ.MINID=1001
GLOBAL_SEQ.MAXID=1000000000
GLOBAL_SEQ.CURID=1000

server.xml

<system>
	<!--0=本地文件,1=数据库,2=时间戳,3=zk,4=zk递增-->
	<property name="sequnceHandlerType">0</property>
</system>

使用方式:insert into t_user (id,name) VALUES (next value for MYCATSEQ_GLOBAL,‘2’)
优点:快
缺点:mycat集群环境下会出现id重复错误

数据库方式

server.xml

<system>
	<!--0=本地文件,1=数据库,2=时间戳-->
	<property name="sequnceHandlerType">1</property>
</system>

sequence_db_conf.properties

USER=dn1

在这里插入图片描述创建表MYCAT_SEQUENCE
在dn1也就是centos101的user1库创建表MYCAT_SEQUENCE(必须大写)
这里很坑,因为我们配置mysql基本上都会配置lower_case_table_names=1,即忽略大小写,都会转为小写处理,而如果你把lower_case_table_names=1注释掉重启mysql,会发现启动不了了。所以安装mysql的时候这个还是不要配置了。

CREATE TABLE MYCAT_SEQUENCE (name VARCHAR(50) NOT NULL,current_value INT NOT 
NULL,increment INT NOT NULL DEFAULT 100, PRIMARY KEY(name)) ENGINE=InnoDB;
--这个USER,即对应sequence_db_conf.properties的USER
INSERT INTO MYCAT_SEQUENCE(name,current_value,increment) VALUES ('USER', 10, 
100);

创建三个函数

创建相应的函数一:传入序列名,获取当前sequence的值
DELIMITER $$
CREATE FUNCTION mycat_seq_currval(SEQ_NAME VARCHAR(50)) RETURNS VARCHAR(64) CHARSET utf8
DETERMINISTIC
BEGIN
DECLARE RETVAL VARCHAR(64);
SET RETVAL = "-999999999,NULL";
SELECT CONCAT(CAST(CURRENT_VALUE AS CHAR), ",", CAST(INCREMENT AS CHAR)) INTO RETVAL FROM MYCAT_SEQUENCE WHERE NAME = SEQ_NAME;
RETURN RETVAL;
END$$
DELIMITER ;


创建相应的函数二:给指定sequence设定当前值(指定具体valueDELIMITER $$
CREATE FUNCTION mycat_seq_setval(SEQ_NAME VARCHAR(50),VALUE INTEGER) RETURNS        VARCHAR(64) CHARSET UTF8
DETERMINISTIC
BEGIN
UPDATE MYCAT_SEQUENCE
SET CURRENT_VALUE = VALUE
WHERE NAME = SEQ_NAME;
RETURN MYCAT_SEQ_CURRVAL(SEQ_NAME);
END$$
DELIMITER ;


创建相应的函数三:给指定sequence设定当前值(当前值=原当前值+步长)

DELIMITER $$
CREATE FUNCTION mycat_seq_nextval(SEQ_NAME VARCHAR(50)) RETURNS VARCHAR(64)  CHARSET UTF8
DETERMINISTIC
BEGIN
UPDATE MYCAT_SEQUENCE
SET CURRENT_VALUE = CURRENT_VALUE + INCREMENT WHERE NAME = SEQ_NAME;
RETURN MYCAT_SEQ_CURRVAL(SEQ_NAME);
END$$
DELIMITER ;

重启mycat测试:

--MYCATSEQ_是固定写法,USER就是对应sequence_db_conf.properties的USER
insert into t_user (id,name) VALUES (next value for MYCATSEQ_USER,'2')

本地时间戳方式

server.xml

<system>
	<!--0=本地文件,1=数据库,2=时间戳-->
	<property name="sequnceHandlerType">2</property>
</system>

sequence_time_conf.properties:默认配置就好

WORKID=0-31 任意整数
DATAACENTERID=0-31 任意整数

多个 mycat 节点下每个 mycat 配置的 WORKID,DATAACENTERID 不同,组成唯一标识,总共支持32*32=1024 种组合

使用:INSERT INTO t_user (NAME)VALUES(‘2’)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值