龙空技术网

MySQL之全局序列

尚硅谷教育 256

前言:

现时兄弟们对“mysql全局表”都比较珍视,姐妹们都想要剖析一些“mysql全局表”的相关文章。那么小编同时在网上网罗了一些对于“mysql全局表””的相关知识,希望我们能喜欢,兄弟们快快来学习一下吧!

1.本地文件

不推荐,存在宕机序列丢失问题。

2.数据库方式

数据库序列方式原理

利用数据库一个表 来进行计数累加。但是并不是每次生成序列都读写数据库,这样效率太低。

mycat会预加载一部分号段到mycat的内存中,这样大部分读写序列都是在内存中完成的。如果内存中的号段用完了 mycat会再向数据库要一次。

如果mycat崩溃了 ,内存中的序列都没了,那么mycat启动后会向数据库申请新的号段,原有号段会弃用。也就是说如果mycat重启,那么损失是当前的号段没用完的号码,但是不会因此出现主键重复。

建库序列脚本

在win10的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;

DELIMITER $$

CREATE FUNCTION mycat_seq_currval(seq_name VARCHAR(50)) RETURNS VARCHAR(64)

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;

DELIMITER $$

CREATE FUNCTION mycat_seq_setval(seq_name VARCHAR(50),VALUE INTEGER) RETURNS VARCHAR(64)

DETERMINISTIC

BEGIN

UPDATE MYCAT_SEQUENCE

SET current_value = VALUE

WHERE NAME = seq_name;

RETURN mycat_seq_currval(seq_name);

END $$

DELIMITER ;

DELIMITER $$

CREATE FUNCTION mycat_seq_nextval(seq_name VARCHAR(50)) RETURNS VARCHAR(64)

DETERMINISTIC

BEGIN

UPDATE MYCAT_SEQUENCE

SET current_value = current_value + increment WHERE NAME = seq_name;

RETURN mycat_seq_currval(seq_name);

END $$

DELIMITER;

SELECT * FROM MYCAT_SEQUENCE

TRUNCATE TABLE MYCAT_SEQUENCE

##增加要用的序列

INSERT INTO MYCAT_SEQUENCE(NAME,current_value,increment) VALUES (‘ORDERS’, 400000,

100);

修改mycat配置

sequence_db_conf.properties

vim sequence_db_conf.properties

意思是 ORDERS这个序列在dn1这个节点上,具体dn1节点是哪台机子,请参考schema.xml

mycat配置server.xml

vim server.xml

重启mycat插入语句

insert into `orders`(id,amount,customer_id,order_type) values(next value for MYCATSEQ_ORDERS,1000,101,102);

3.时间戳方式

需要18位字段,比较长。

4.自主生成

根据业务逻辑组合

可以利用 redis的单线程原子性 incr来生成序列

java 枚举的定义与用法

Java 的抽象类是什么

java之数据格式化

Java 数据结构都有哪些

java技术事务的传播行为

标签: #mysql全局表