成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

mysql怎么做序列 回到古代當皇子介紹

mysql如何創(chuàng)建一個序列

序列只有db2

微山網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運營維護。成都創(chuàng)新互聯(lián)公司從2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)公司。

oracle有,mysql沒有序列的,不過你可以給你所所創(chuàng)建的表的主鍵設(shè)置為自增。

例如

create

table

A

(

id

int(20)

auto_increment

)

不過設(shè)置為自增的鍵必須是數(shù)值類型的。

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

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

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

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

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

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

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

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,

--當前值

increment_val

INT

NOT

NULL

DEFAULT

1,

--步長(跨度)

PRIMARY

KEY

(seq_name)

);

實現(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');

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

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

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

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

您可能感興趣的文章:mysql實現(xiàn)sequence功能的代碼Can''t

connect

to

local

MySQL

through

socket

''/tmp/mysql.sock''解決方法Mysql常用函數(shù)大全(分類匯總講解)利用MySQL主從配置實現(xiàn)讀寫分離減輕數(shù)據(jù)庫壓力mysql+spring+mybatis實現(xiàn)數(shù)據(jù)庫讀寫分離的代碼配置Golang中如何對MySQL進行操作詳解將圖片儲存在MySQL數(shù)據(jù)庫中的幾種方法MySQL存儲文本和圖片的方法Ubuntu上mysql的安裝及使用(通用版)nodejs同步調(diào)用獲取mysql數(shù)據(jù)時遇到的大坑

mysql 如何創(chuàng)建序列?

比如說你創(chuàng)建了一個表userinfos

create table userinfos(

userid int primary key,

username varchar(20)

);

//給userinfos添加序列

update userinfos set userid = last_insert_id(userid+1);

//然后查詢序列

select last_insert_id();

或者也可以這樣

create table userinfos(

userid int primary key not null auto_increment,

username varchar(20)

);

網(wǎng)頁標題:mysql怎么做序列 回到古代當皇子介紹
文章來源:http://jinyejixie.com/article12/ddojhdc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)企業(yè)網(wǎng)站制作、手機網(wǎng)站建設(shè)網(wǎng)站設(shè)計公司、商城網(wǎng)站、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)
化德县| 商洛市| 彰化县| 沅江市| 邓州市| 惠东县| 扶余县| 都江堰市| 曲周县| 环江| 横山县| 高唐县| 连山| 克东县| 育儿| 渝北区| 平安县| 郓城县| 炎陵县| 会宁县| 额济纳旗| 巢湖市| 广东省| 稻城县| 子长县| 读书| 札达县| 翁源县| 岱山县| 鄂伦春自治旗| 博罗县| 五河县| 城市| 白玉县| 洞头县| 志丹县| 桓台县| 津南区| 于都县| 英吉沙县| 且末县|