mysql實(shí)現(xiàn)自增序列的示例代碼
1.創(chuàng)建sequence表
CREATE TABLE `sequence` ( `name` varchar(50) COLLATE utf8_bin NOT NULL COMMENT ’序列的名字’, `current_value` int(11) NOT NULL COMMENT ’序列的當(dāng)前值’, `increment` int(11) NOT NULL DEFAULT ’1’ COMMENT ’序列的自增值’, PRIMARY KEY (`name`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
2.創(chuàng)建?取當(dāng)前值的函數(shù)
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.創(chuàng)建?取下一個(gè)值的函數(shù)
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.創(chuàng)建?更新當(dāng)前值的函數(shù)
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.測(cè)試添加實(shí)例 執(zhí)行sql
INSERT INTO sequence VALUES (’testSeq’, 0, 1);-- 添加一個(gè)sequence名稱和初始值,以及自增幅度 SELECT SETVAL(’testSeq’, 10);-- 設(shè)置指定sequence的初始值 SELECT CURRVAL(’testSeq’);-- 查詢指定sequence的當(dāng)前值 SELECT NEXTVAL(’testSeq’);-- 查詢指定sequence的下一個(gè)值
到此這篇關(guān)于mysql實(shí)現(xiàn)自增序列的示例代碼的文章就介紹到這了,更多相關(guān)mysql 自增序列內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 什么是Access數(shù)據(jù)庫(kù)2. Oracle學(xué)習(xí)筆記之二----查詢3. SQLite3的綁定函數(shù)族使用與其注意事項(xiàng)詳解4. Access中批量替換數(shù)據(jù)庫(kù)內(nèi)容的兩種方法5. 詳解MySQL中的數(shù)據(jù)類型和schema優(yōu)化6. 數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能:ACCESS轉(zhuǎn)SQL7. Linux安裝ODBC連接SQLServer數(shù)據(jù)庫(kù)的步驟8. idea連接sql sever2019圖文教程(超詳細(xì))9. Sqlserver之死鎖查詢以及批量解鎖的實(shí)現(xiàn)方法10. SQL Server連接中的常見(jiàn)錯(cuò)誤
