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ù),用于獲取序列表中的值;
具體如下:
表結構為:
drop table if exists sequence;
create table sequence (
seq_name VARCHAR(50) NOT NULL, -- 序列名稱
current_val INT NOT NULL, --當前值
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ù)
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ù)庫字段要對應上
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 $$
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
您可能感興趣的文章:- 詳解MySQL實時同步到Oracle解決方案
- Mysql、Oracle中常用的多表修改語句總結
- mysql和oracle的區(qū)別小結(功能性能、選擇、使用它們時的sql等對比)
- mysql數(shù)據(jù)庫和oracle數(shù)據(jù)庫之間互相導入備份
- 抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫的實現(xiàn)過程
- Oracle和MySQL的高可用方案對比分析
- MySQL與Oracle 差異比較之六觸發(fā)器
- MySQL與Oracle差異比較之五存儲過程&Function
- MySQL與Oracle差異比較之三 函數(shù)
- 詳解Mysql和Oracle之間的誤區(qū)