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)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- mysql自增ID起始值修改方法
- mysql如何讓自增id歸0解決方案
- 怎么重置mysql的自增列AUTO_INCREMENT初時(shí)值
- Java獲取最后插入MySQL記錄的自增ID值的3種方法
- mysql中自增auto_increment功能的相關(guān)設(shè)置及問題
- MySQL rownumber SQL生成自增長序號(hào)使用介紹
- 關(guān)于Mysql自增id的這些你可能還不知道
- MySQL分表自增ID問題的解決方法
- mysql自增id超大問題的排查與解決
- mysql修改自增長主鍵int類型為char類型示例
- 利用Java的MyBatis框架獲取MySQL中插入記錄時(shí)的自增主鍵
相關(guān)文章
mysql?explain中key_len的含義以及計(jì)算方法
通常在優(yōu)化SQL查詢的時(shí)候,我們都會(huì)使用explain分析SQL執(zhí)行計(jì)劃,下面這篇文章主要給大家介紹了關(guān)于mysql?explain中key_len的含義以及計(jì)算方法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03MySQL Community Server壓縮包安裝配置方法
這篇文章主要為大家詳細(xì)介紹了MySQL Community Server壓縮包安裝配置方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11MySQL無法重啟報(bào)錯(cuò)Warning: World-writable config file ‘/etc/my.cnf’
最近在維護(hù)公司服務(wù)器的時(shí)候,在關(guān)閉數(shù)據(jù)庫的命令發(fā)現(xiàn)mysql關(guān)不了了,提示錯(cuò)誤為Warning: World-writable config file '/etc/my.cnf' is ignored,通過查找網(wǎng)上的資料終于解決了,現(xiàn)在將解決的方法分享給大家,同樣遇到這個(gè)問題的朋友們可以參考借鑒。2016-12-12MySQL數(shù)據(jù)庫分組查詢group by語句詳解
這篇文章主要介紹了MySQL數(shù)據(jù)庫分組查詢group by語句詳解,文中含有詳細(xì)示例代碼說明解析,有需要的朋友可以借鑒參考想=下,希望能夠有所幫助2021-09-09