使用函數(shù)創(chuàng)建自增序列管理表(批量使用自增表,設(shè)置初始值,自增幅度)
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的衡陽(yáng)網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
MySQL實(shí)現(xiàn)類(lèi)似Oracle的序列
Oracle一般使用序列(Sequence)來(lái)處理主鍵字段,而MySQL則提供了自增長(zhǎng)(increment)來(lái)實(shí)現(xiàn)類(lèi)似的目的;
但在實(shí)際使用過(guò)程中發(fā)現(xiàn),MySQL的自增長(zhǎng)有諸多的弊端:不能控制步長(zhǎng)、開(kāi)始索引、是否循環(huán)等;若需要遷移數(shù)據(jù)庫(kù),則對(duì)于主鍵這塊,也是個(gè)頭大的問(wèn)題。
本文記錄了一個(gè)模擬Oracle序列的方案,重點(diǎn)是想法,代碼其次。
Oracle序列的使用,無(wú)非是使用.nextval和.currval偽列,基本想法是:
1、MySQL中新建表,用于存儲(chǔ)序列名稱和值;
2、創(chuàng)建函數(shù),用于獲取序列表中的值;
具體如下:
表結(jié)構(gòu)為:
drop
table
if
exists
sequence;
create
table
sequence
(
seq_name
VARCHAR(50)
NOT
NULL,
--
序列名稱
current_val
INT
NOT
NULL,
--當(dāng)前值
increment_val
INT
NOT
NULL
DEFAULT
1,
--步長(zhǎng)(跨度)
PRIMARY
KEY
(seq_name)
);
實(shí)現(xiàn)currval的模擬方案
create
function
currval(v_seq_name
VARCHAR(50))
returns
integer
begin
declare
value
integer;
set
value
=
0;
select
current_value
into
value
from
sequence
where
seq_name
=
v_seq_name;
return
value;
end;
函數(shù)使用為:select
currval('MovieSeq');
實(shí)現(xiàn)nextval的模擬方案
create
function
nextval
(v_seq_name
VARCHAR(50))
return
integer
begin
update
sequence
set
current_val
=
current_val
+
increment_val
where
seq_name
=
v_seq_name;
return
currval(v_seq_name);
end;
函數(shù)使用為:select
nextval('MovieSeq');
增加設(shè)置值的函數(shù)
create
function
setval(v_seq_name
VARCHAR(50),
v_new_val
INTEGER)
returns
integer
begin
update
sequence
set
current_val
=
v_new_val
where
seq_name
=
v_seq_name;
return
currval(seq_name);
同理,可以增加對(duì)步長(zhǎng)操作的函數(shù),在此不再敘述。
注意語(yǔ)法,數(shù)據(jù)庫(kù)字段要對(duì)應(yīng)上
use
bvboms;
DELIMITER
$$
create
function
setval(v_seq_name
VARCHAR(50),
v_new_val
INTEGER)
returns
integer
begin
update
sequence
set
current_val
=
v_new_val
where
seq_name
=
v_seq_name;
return
currval(seq_name);
end
$$
DELIMITER
$$
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
您可能感興趣的文章:mysql實(shí)現(xiàn)sequence功能的代碼Can''t
connect
to
local
MySQL
through
socket
''/tmp/mysql.sock''解決方法Mysql常用函數(shù)大全(分類(lèi)匯總講解)利用MySQL主從配置實(shí)現(xiàn)讀寫(xiě)分離減輕數(shù)據(jù)庫(kù)壓力mysql+spring+mybatis實(shí)現(xiàn)數(shù)據(jù)庫(kù)讀寫(xiě)分離的代碼配置Golang中如何對(duì)MySQL進(jìn)行操作詳解將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法MySQL存儲(chǔ)文本和圖片的方法Ubuntu上mysql的安裝及使用(通用版)nodejs同步調(diào)用獲取mysql數(shù)據(jù)時(shí)遇到的大坑
只能再查詢自增ID即可
具體操作:MYSQL獲取自增ID的四種方法
select max(id) from tablename
SELECT LAST_INSERT_ID() 函數(shù)
LAST_INSERT_ID 是與table無(wú)關(guān)的,如果向表a插入數(shù)據(jù)后,再向表b插入數(shù)據(jù),LAST_INSERT_ID會(huì)改變。