概述
由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能。
1、创建sequence表
- CREATE TABLE `sequence` (
- `name` VARCHAR ( 50 ) COLLATE utf8_bin NOT NULL COMMENT '序列的名字',
- `current_value` INT ( 11 ) NOT NULL COMMENT '序列的当前值',
- `increment` INT ( 11 ) NOT NULL DEFAULT '1' COMMENT '序列的自增值',
- PRIMARY KEY ( `name` )
- ) ENGINE = INNODB DEFAULT CHARSET = utf8 COLLATE = utf8_bin;
2、创建–取当前值的函数
- DROP FUNCTION IF EXISTS currval;
- DELIMITER $
- CREATE FUNCTION currval (seq_name VARCHAR(50))
- RETURNS INTEGER
- LANGUAGE SQL
- DETERMINISTIC
- CONTAINS SQL
- SQL SECURITY DEFINER
- COMMENT ''
- BEGIN
- DECLARE value INTEGER;
- SET value = 0;
- SELECT current_value INTO value
- FROM sequence
- WHERE name = seq_name;
- RETURN value;
- END
- $
- DELIMITER ;
3、创建–取下一个值的函数
- DROP FUNCTION IF EXISTS nextval;
- DELIMITER $
- CREATE FUNCTION nextval (seq_name VARCHAR(50))
- RETURNS INTEGER
- LANGUAGE SQL
- DETERMINISTIC
- CONTAINS SQL
- SQL SECURITY DEFINER
- COMMENT ''
- BEGIN
- UPDATE sequence
- SET current_value = current_value + increment
- WHERE name = seq_name;
- RETURN currval(seq_name);
- END
- $
- DELIMITER ;
4、创建–更新当前值的函数
- DROP FUNCTION IF EXISTS setval;
- DELIMITER $
- CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)
- RETURNS INTEGER
- LANGUAGE SQL
- DETERMINISTIC
- CONTAINS SQL
- SQL SECURITY DEFINER
- COMMENT ''
- BEGIN
- UPDATE sequence
- SET current_value = value
- WHERE name = seq_name;
- RETURN currval(seq_name);
- END
- $
- DELIMITER ;
5、测试
- INSERT INTO sequence VALUES ('hwb_Seq', 0, 1);--添加一个sequence名称和初始值,以及自增幅度
- SELECT SETVAL('hwb_Seq', 10);--设置指定sequence的初始值
- SELECT CURRVAL('hwb_Seq');--查询指定sequence的当前值
- SELECT NEXTVAL('hwb_Seq');--查询指定sequence的下一个值
这里,hwb_Seq可以认为是一个表名,通过insert语句插入指定表的第一个序列,然后使用NEXTVAL方法,不断更新这一列数据,来获取下一个序列的值。可以通过这张表,来实现N张表的自增序列的统一管理。
近2年Docker非常的火热,各位开发者恨不得把所有的应用、软件都部署在Docker容器...
前言 NLog是一个基于.NET平台编写的类库,我们可以使用NLog在应用程序中添加极为...
本文实例为大家分享了ajax实现三级联动的具体代码,供大家参考,具体内容如下 1....
需求: 根据业务要求,需要能够上传图片,且上传的图片能在移动端中占满屏幕宽度...
前言: 做过游戏开发的人都知道,端游可以用c++,页游可以用sl或者as3,鉴于这段时...
引子 对于真实系统或者仿真平台,数据是增量式的产生的。Matlab除了强大的矩阵运...
一、为图片添加水印 复制代码 代码如下: % Dim Jpeg ''''//声明变量 Set Jpeg = ...
大家好,我是狂聊君。 今天来聊一聊 Mysql 缓存池原理。 提纲附上,话不多说,直...
要开发.NET Core应用程序,除了使用强大的Visual Studio之外,还可以使用.NET Co...
快照和复制技术的结合可以保证我们得到一个实时的在线MySQL备份解决方案 当主库...