国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

mysql實現自增序列的示例代碼

瀏覽:2日期:2023-10-05 17:14:33

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.測試添加實例 執行sql

INSERT INTO sequence VALUES (’testSeq’, 0, 1);-- 添加一個sequence名稱和初始值,以及自增幅度 SELECT SETVAL(’testSeq’, 10);-- 設置指定sequence的初始值 SELECT CURRVAL(’testSeq’);-- 查詢指定sequence的當前值 SELECT NEXTVAL(’testSeq’);-- 查詢指定sequence的下一個值

到此這篇關于mysql實現自增序列的示例代碼的文章就介紹到這了,更多相關mysql 自增序列內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 台州市| 化隆| 宜川县| 平山县| 兴业县| 宁强县| 晋江市| 东乌珠穆沁旗| 沾化县| 峨边| 西平县| 新平| 苗栗县| 运城市| 德庆县| 北辰区| 湖口县| 独山县| 固阳县| 赤水市| 柳林县| 哈巴河县| 杨浦区| 临高县| 河源市| 安宁市| 固镇县| 剑川县| 黎平县| 合江县| 龙海市| 图木舒克市| 黄龙县| 睢宁县| 湛江市| 陆河县| 且末县| 嵩明县| 绥德县| 新津县| 上高县|