真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

mysql序列怎么用,mysql序列和索引

MySQL 序列使用

使用函數(shù)創(chuàng)建自增序列管理表(批量使用自增表,設(shè)置初始值,自增幅度)

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的衡陽(yáng)網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

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

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

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

但在實(shí)際使用過(guò)程中發(fā)現(xiàn),MySQL的自增長(zhǎng)有諸多的弊端:不能控制步長(zhǎng)、開(kāi)始索引、是否循環(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í)現(xiàn)sequence功能的代碼Can''t

connect

to

local

MySQL

through

socket

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

如何使用mysql 一次查詢多個(gè)序列

只能再查詢自增ID即可

具體操作:MYSQL獲取自增ID的四種方法

select max(id) from tablename

SELECT LAST_INSERT_ID() 函數(shù)

LAST_INSERT_ID 是與table無(wú)關(guān)的,如果向表a插入數(shù)據(jù)后,再向表b插入數(shù)據(jù),LAST_INSERT_ID會(huì)改變。


網(wǎng)站題目:mysql序列怎么用,mysql序列和索引
新聞來(lái)源:http://weahome.cn/article/hdhpcj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部