好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

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

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

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

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è)頭大的問(wèn)題。

本文記錄了一個(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ū)

標(biāo)簽:拉薩 洛陽(yáng) 安徽 吐魯番 葫蘆島 海口 嘉峪關(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)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL實(shí)現(xiàn)類似Oracle序列的方案》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL實(shí)現(xiàn)類似Oracle序列的方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 色戒未删| 被黑人猛躁10次高潮的最新动态| 美女脱个精光露出奶胸网站| 大尺度吃奶呻吟视频3D| 日本瑜伽电影| japonensisjava教师下载| 精久久| 国产黄色免费观看| 丰满人妻一区二区三区蜜桃视频 | 健身教练在后面蹭硬了 | 十七岁韩国高清完整在线观看| 成品抖音短视频在线看怎么弄| 苹果在线播放| 黄色ed2k| 男生操女生逼逼| 亚洲人成人伊人成综合网无码,久| 国产younv真实| 91在无码线精品秘?入口九色| 日本欧美一区二区三区免费不卡| 玖操在线| 欧美特黄a级高清免费看片| 国产国语老龄妇女A片| 免费在线资源| 小孩和小孩差差的视频| 小荡货爽cao| 七十老太亂伦 性最老的老太大| 综合色婷婷一区二区亚洲欧美国产| 公交车上站着被h| 麻豆国产AV精品一区二区 | 插妞| 一级做a爱夜晚久久毛片| 男人脱美女衣服摸全身视频| 国产精品一区二区制服丝袜| 欧美野外多人交3| xxxnxxx69| 好爽?要了?再深点久久口| 精品国产高清伦理| 日本理论片免费观看在线视频| 亚洲免费成人| 老头猛的挺进她莹莹的体视频| 亚洲 激情 图片 小说|