婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL實現類似Oracle序列的方案

MySQL實現類似Oracle序列的方案

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

MySQL實現類似Oracle的序列

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

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

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

Oracle序列的使用,無非是使用.nextval和.currval偽列,基本想法是:

1、MySQL中新建表,用于存儲序列名稱和值;

2、創建函數,用于獲取序列表中的值;

具體如下:

表結構為: 

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

實現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;

函數使用為:select currval('MovieSeq'); 

實現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;

函數使用為:select nextval('MovieSeq');  

增加設置值的函數

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

同理,可以增加對步長操作的函數,在此不再敘述。

注意語法,數據庫字段要對應上

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的區別小結(功能性能、選擇、使用它們時的sql等對比)
  • mysql數據庫和oracle數據庫之間互相導入備份
  • 抽取oracle數據到mysql數據庫的實現過程
  • Oracle和MySQL的高可用方案對比分析
  • MySQL與Oracle 差異比較之六觸發器
  • MySQL與Oracle差異比較之五存儲過程&Function
  • MySQL與Oracle差異比較之三 函數
  • 詳解Mysql和Oracle之間的誤區

標簽:拉薩 洛陽 安徽 吐魯番 葫蘆島 海口 嘉峪關 甘南

巨人網絡通訊聲明:本文標題《MySQL實現類似Oracle序列的方案》,本文關鍵詞  MySQL,實現,類似,Oracle,序列,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL實現類似Oracle序列的方案》相關的同類信息!
  • 本頁收集關于MySQL實現類似Oracle序列的方案的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 湖口县| 石棉县| 周宁县| 葵青区| 虎林市| 宜阳县| 常州市| 华坪县| 五莲县| 黄梅县| 深水埗区| 钦州市| 化德县| 开鲁县| 远安县| 乌拉特前旗| 波密县| 阿坝县| 岢岚县| 内黄县| 河北省| 项城市| 南漳县| 湖北省| 邵武市| 巫溪县| 泰安市| 伊宁市| 尖扎县| 玉田县| 芒康县| 浦城县| 柘荣县| 兴安县| 岑巩县| 七台河市| 花莲市| 邢台县| 九龙县| 阜新| 永修县|