• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL 简易序列

mysql 搞代码 4年前 (2022-01-09) 23次浏览 已收录 0个评论

这是为 MySQL 编写的简易序列存储程序(一个函数)。 在使用序列之前,需要通过往序列记录表中加入数值的方式初始化序列: INSERT INTO Sequence (‘name…’, 0); 之后,就可以通过 nextval(‘name…’) 函数来取得名为 name… 的序列新值。 考虑到 update 自

这是为 MySQL 编写的简易序列存储程序(一个函数)。
在使用序列之前,需要通过往序列记录表中加入数值的方式初始化序列:
INSERT INTO Sequence (‘name…’, 0);
之后,就可以通过 nextval(‘name…’) 函数来取得名为 name… 的序列新值。
考虑到 update 自身的行锁能力。所以本序列程序具有很强的并发提供能力。
<style> .CodeEntity .code_pieces ul.piece_anchor{width:25px;position:absolute;top:25px;left:-30px;z-index:1000;} .CodeEntity .code_pieces ul.piece_anchor li{width:25px;background: #efe;margin-bottom:2px;} .CodeEntity .code_pieces ul.piece_anchor li{border-left:3px #40AA63 solid;border-right:3px #efe solid;} .CodeEntity .code_pieces ul.piece_anchor li:hover{border-right:3px #40AA63 solid;border-left:3px #efe solid;} .CodeEntity .code_pieces ul.piece_anchor li a{color: #333;padding: 3px 10px;} .CodeEntity .code_pieces .jump_to_code{visibility:hidden;position:relative;} .CodeEntity .code_pieces .code_piece:hover .jump_to_code{visibility:visible;} .CodeEntity .code_pieces .code_piece:hover .jump_to_code a{text-decoration:none;} .CodeEntity .code_pieces h2 i{float:right;font-style:normal;font-weight:normal;} .CodeEntity .code_pieces h2 i a{font-size:9pt;background: #FFFFFF;color:#00A;padding: 2px 5px;text-decoration:none;} </style> <!—ecms

    –> <!—ecms

  • $velocityCount
  • –> <!—ecms

–>

DROP TABLE IF EXISTS Sequence;CREATE TABLE Sequence(  name      VARCHAR(32),  maxIndex  INTEGER,  CONSTRAINT cst_Sequence_pk PRIMARY KEY (name, maxIndex)) DEFAULT CHARACTER SET utf8ENGINE InnoDB;
SET GLOBAL log_bin_trust_function_creators = 1;DROP FUNCTION IF EXISTS nextval;DELIMITER //CREATE FUNCTION nextval(sequenceName VARCHAR(32))  RETURNS INTEGER  NOT DETERMINISTIC  CONTAINS SQL/* ********** ********** ********** **********This is a common sequence function. It is based on table Sequence.This function will return new integer by given sequence name.author:		Shane Loo Liversion:	1.1.1, 2012-7-17 Tuesday	Modified edition.history:1.1.0, 2012-7-14 Saturday	Shane Loo Li	New1.1.1, 2012-7-17 Tuesday	Shane Loo Li	Modified wrong column name.********** ********** ********** ********** */BEGIN  DECLARE iMaxIndex INTEGER;  UPDATE Sequence SET maxIndex = ma<strong style="color:transparent">本文来源gaodai#ma#com搞@@代~&码*网/</strong>xIndex + 1 WHERE name = sequenceName;  SELECT maxIndex INTO iMaxIndex    FROM Sequence WHERE name = sequenceName;  RETURN iMaxIndex;END//DELIMITER ;

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL 简易序列
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址