MySQL實現(xiàn)類似Oracle的序列
Oracle一般使用序列(Sequence)來處理主鍵字段,而MySQL則提供了自增長(increment)來實現(xiàn)類似的目的;
但在實際使用過程中發(fā)現(xiàn),MySQL的自增長有諸多的弊端:不能控制步長、開始索引、是否循環(huán)等;若需要遷移數(shù)據(jù)庫,則對于主鍵這塊,也是個頭大的問題。
本文記錄了一個模擬Oracle序列的方案,重點是想法,代碼其次。
Oracle序列的使用,無非是使用.nextval和.currval偽列,基本想法是:
1、MySQL中新建表,用于存儲序列名稱和值;
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, --步長(跨度) PRIMARY KEY (seq_name) );
實現(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');
實現(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);
同理,可以增加對步長操作的函數(shù),在此不再敘述。
注意語法,數(shù)據(jù)庫字段要對應(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é)
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com