亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL實現類似Oracle序列的方案

發布時間:2020-10-12 21:58:05 來源:腳本之家 閱讀:195 作者:走過的足跡 欄目:MySQL數據庫

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 $$

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

聂拉木县| 蕲春县| 定襄县| 临沧市| 彰化市| 盘山县| 富裕县| 禄劝| 嵩明县| 宁明县| 丹阳市| 吴桥县| 五家渠市| 咸宁市| 拜城县| 临湘市| 新沂市| 布拖县| 铁岭市| 京山县| 南郑县| 姜堰市| 邵阳县| 枝江市| 望城县| 托克逊县| 宁城县| 杭锦后旗| 桦南县| 富锦市| 东乡县| 曲阜市| 大英县| 宜丰县| 牙克石市| 呈贡县| 扬中市| 昭苏县| 东安县| 阿拉善左旗| 边坝县|