博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
给MySQL增加Sequence管理功能
阅读量:5306 次
发布时间:2019-06-14

本文共 1707 字,大约阅读时间需要 5 分钟。

-- Sequence 管理表DROP TABLE IF EXISTS sequence;CREATE TABLE sequence (         name VARCHAR(50) NOT NULL,         current_value INT NOT NULL,         increment INT NOT NULL DEFAULT 1,         PRIMARY KEY (name)) ENGINE=InnoDB; -- 取当前值的函数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 ; -- 取下一个值的函数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 ; -- 更新当前值的函数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 ;/*-- 测试INSERT INTO sequence VALUES ('TestSeq', 0, 1);SELECT SETVAL('TestSeq', 10);SELECT CURRVAL('TestSeq');SELECT NEXTVAL('TestSeq');*/

 

转载于:https://www.cnblogs.com/smile361/archive/2013/05/16/3082182.html

你可能感兴趣的文章
正则表达式
查看>>
pip install torch on windows, and the 'from torch._C import * ImportError: DLL load failed:' s...
查看>>
环套树
查看>>
java基础(一):我对java的三个环境变量的简单理解和配置
查看>>
arcgis api 4.x for js 结合 Echarts4 实现散点图效果(附源码下载)
查看>>
YTU 2625: B 构造函数和析构函数
查看>>
apache自带压力测试工具ab的使用及解析
查看>>
C#使用Xamarin开发可移植移动应用(2.Xamarin.Forms布局,本篇很长,注意)附源码
查看>>
jenkins搭建
查看>>
C#中使用Split分隔字符串的技巧
查看>>
eclipse的调试方法的简单介绍
查看>>
加固linux
查看>>
IPSP问题
查看>>
HNU 10362 A+B for Input-Output Practice (II)
查看>>
10.17动手动脑
查看>>
WPF中Image显示本地图片
查看>>
Windows Phone 7你不知道的8件事
查看>>
脚本删除文件下的文件
查看>>
实用拜占庭容错算法PBFT
查看>>
java的二叉树树一层层输出,Java构造二叉树、树形结构先序遍历、中序遍历、后序遍历...
查看>>