MySQL實(shí)現(xiàn)類似Oracle序列的方案
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)鏈接
- 詳解MySQL實(shí)時(shí)同步到Oracle解決方案
- Mysql、Oracle中常用的多表修改語(yǔ)句總結(jié)
- mysql和oracle的區(qū)別小結(jié)(功能性能、選擇、使用它們時(shí)的sql等對(duì)比)
- mysql數(shù)據(jù)庫(kù)和oracle數(shù)據(jù)庫(kù)之間互相導(dǎo)入備份
- 抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)過(guò)程
- Oracle和MySQL的高可用方案對(duì)比分析
- MySQL與Oracle 差異比較之六觸發(fā)器
- MySQL與Oracle差異比較之五存儲(chǔ)過(guò)程&Function
- MySQL與Oracle差異比較之三 函數(shù)
- 詳解Mysql和Oracle之間的誤區(qū)
相關(guān)文章
解決創(chuàng)建主鍵報(bào)錯(cuò):Incorrect column specifier for
這篇文章主要介紹了解決創(chuàng)建主鍵報(bào)錯(cuò):Incorrect column specifier for column‘id‘問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08mysql獲取排列序號(hào)的三種常用方法小結(jié)
這篇文章主要介紹了mysql獲取排列序號(hào)的三種常用方法,并通過(guò)代碼示例和圖文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-03-03

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