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

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

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

瀏覽:6日期: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 數據庫
相關文章:
主站蜘蛛池模板: 富顺县| 甘南县| 建宁县| 华宁县| 京山县| 宁武县| 北海市| 昔阳县| 繁昌县| 扶余县| 昌吉市| 邯郸市| 菏泽市| 牙克石市| 白水县| 宜丰县| 桑日县| 许昌市| 阜南县| 龙泉市| 海兴县| 博罗县| 沅江市| 平定县| 莫力| 开化县| 大理市| 三原县| 桃园县| 信丰县| 吉安市| 玛纳斯县| 定襄县| 天等县| 广安市| 三门县| 万宁市| 连山| 商都县| 卢龙县| 九台市|