主頁 > 知識庫 > MySQL實(shí)現(xiàn)類似Oracle序列的方案

MySQL實(shí)現(xiàn)類似Oracle序列的方案

熱門標(biāo)簽:百度地圖標(biāo)注后不顯示 溫州瑞安400電話怎么申請 俄國地圖標(biāo)注app 電銷機(jī)器人各個細(xì)節(jié)介紹 淄博400電話申請 昆明電信400電話辦理 電話機(jī)器人市場趨勢 南昌高頻外呼系統(tǒng)哪家公司做的好 電銷機(jī)器人 行業(yè)

MySQL實(shí)現(xiàn)類似Oracle的序列

Oracle一般使用序列(Sequence)來處理主鍵字段,而MySQL則提供了自增長(increment)來實(shí)現(xiàn)類似的目的;

但在實(shí)際使用過程中發(fā)現(xiàn),MySQL的自增長有諸多的弊端:不能控制步長、開始索引、是否循環(huán)等;若需要遷移數(shù)據(jù)庫,則對于主鍵這塊,也是個頭大的問題。

本文記錄了一個模擬Oracle序列的方案,重點(diǎn)是想法,代碼其次。

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)  
);

實(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);

同理,可以增加對步長操作的函數(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é)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

您可能感興趣的文章:
  • 詳解MySQL實(shí)時同步到Oracle解決方案
  • Mysql、Oracle中常用的多表修改語句總結(jié)
  • mysql和oracle的區(qū)別小結(jié)(功能性能、選擇、使用它們時的sql等對比)
  • mysql數(shù)據(jù)庫和oracle數(shù)據(jù)庫之間互相導(dǎo)入備份
  • 抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫的實(shí)現(xiàn)過程
  • Oracle和MySQL的高可用方案對比分析
  • MySQL與Oracle 差異比較之六觸發(fā)器
  • MySQL與Oracle差異比較之五存儲過程&Function
  • MySQL與Oracle差異比較之三 函數(shù)
  • 詳解Mysql和Oracle之間的誤區(qū)

標(biāo)簽:拉薩 洛陽 安徽 吐魯番 葫蘆島 嘉峪關(guān) 甘南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL實(shí)現(xiàn)類似Oracle序列的方案》,本文關(guān)鍵詞  MySQL,實(shí)現(xiàn),類似,Oracle,序列,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL實(shí)現(xiàn)類似Oracle序列的方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL實(shí)現(xiàn)類似Oracle序列的方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章