欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年03月14日 11:25:21   作者:走過(guò)的足跡  
今天小編就為大家分享一篇關(guān)于MySQL實(shí)現(xiàn)類似Oracle序列的方案,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧

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

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

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

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

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

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

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, --步長(zhǎng)(跨度)  
  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);

同理,可以增加對(duì)步長(zhǎng)操作的函數(shù),在此不再敘述。

注意語(yǔ)法,數(shù)據(jù)庫(kù)字段要對(duì)應(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é)

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

相關(guān)文章

  • mysql 8.0.12安裝配置方法圖文教程(Windows版)

    mysql 8.0.12安裝配置方法圖文教程(Windows版)

    這篇文章主要為大家詳細(xì)介紹了Windows下mysql 8.0.12安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • mysql delete limit 使用方法詳解

    mysql delete limit 使用方法詳解

    今天研究cms系統(tǒng)的時(shí)候發(fā)現(xiàn),delete 語(yǔ)句后面有個(gè)limit,一直都是select查詢的時(shí)候才使用,不懂為什么要用這個(gè),正好就百度一下為大家分享下delete中使用limit方法與有點(diǎn)
    2014-11-11
  • 登錄mysql數(shù)據(jù)庫(kù)的幾種方式

    登錄mysql數(shù)據(jù)庫(kù)的幾種方式

    本文主要介紹了登錄mysql數(shù)據(jù)庫(kù)的幾種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Mysql三種常用的刪除數(shù)據(jù)或者表的方式

    Mysql三種常用的刪除數(shù)據(jù)或者表的方式

    本文主要介紹了Mysql三種常用的刪除數(shù)據(jù)或者表的方式,它們分別是?TRUNCATE、DROP?和?DELETE,下面就詳細(xì)的介紹一下這三種的使用,感興趣的可以了解一下
    2024-01-01
  • 最新評(píng)論