《Mysql入門利用mysql事務(wù)特性實現(xiàn)并發(fā)安全的自增ID示例》要點:
本文介紹了Mysql入門利用mysql事務(wù)特性實現(xiàn)并發(fā)安全的自增ID示例,希望對您有用。如果有疑問,可以聯(lián)系我們。
項目中經(jīng)常會用到自增id,比如uid,最簡單的辦法就是用直接用數(shù)據(jù)庫提供的AUTO_INCREMENT,但是如果用戶量非常大,幾千萬,幾億然后需要分表存儲的時候呢,這種方案就搞不定了,所以最好有一個全局的自增ID的生成器,不管是否分表,都能從生成器中獲取到全局自增的ID.
實現(xiàn)辦法應(yīng)該有很多,不過所有的方案都需要解決一個問題,就是保證在高并發(fā)的情景下,數(shù)據(jù)獲取依然正確,每次獲取的ID都不會重復(fù).
這里我分享兩種利用mysql的innodb的事務(wù)特性來實現(xiàn)的方案,一種是實現(xiàn)過了的,另一種沒有試驗過,不過應(yīng)該也能走的通.
先介紹第一種,在數(shù)據(jù)庫中單獨設(shè)置一張表,來存儲ID,表有兩個字段,一個是種類吧,一個就是ID:
代碼如下:
CREATE TABLE auto_id(
idname varchar(20) NOT NULL DEFAULT '',
id bigint(20) NOT NULL DEFAULT 0 COMMENT '',
primary key(idname)
)ENGINE=Innodb DEFAULT CHARSET=utf8;
接下來是一個存儲過程:
代碼如下:
delimiter //
drop procedure if exists get_increment_id;
create procedure get_increment_id(in idname_in varchar(20), in small_in bigint, out id_out bigint)
begin
declare oldid bigint;
start transaction;
select id into oldid from maibo_auto_id where idname=idname_in for update;
if oldid is NULL then
insert into maibo_auto_id(idname,id) value(idname_in, small_in);
set id_out=small_in;
else
update maibo_auto_id set id=id+1 where idname=idname_in;
set id_out=oldid+1;
end if;
commit;
end;
//
重點是這句,select id into oldid from maibo_auto_id where idname=idname_in for update,會給相關(guān)數(shù)據(jù)加一個獨占鎖定,這時候別的進程如果來讀取該條記錄,就會進入等待,等待這個進程commit之后,再繼續(xù),這樣就保證了在并發(fā)的情況下,不同的進程不會取到相同的值.
如果你的前端是用php實現(xiàn)的.
只需執(zhí)行如下兩個sql,就可以獲取到,這個small參數(shù)是定義的是從多少開始自增
代碼如下:
$sql = "call get_increment_id('{$key}', {$small}, @id)";
$ret = $db->getData("select @id");
還有另外一種辦法,就是利用mysql的auto_increment.
先創(chuàng)建一張表,表里邊只有一個自增字段:
代碼如下:
create table test(
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id',
primary key (id)
)ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
通過如下兩條sql:
代碼如下:
UPDATE test SET id = LAST_INSERT_ID(id + 1);
SELECT LAST_INSERT_ID();
也能辦理問題, LAST_INSERT_ID是不用查表的,而且只針對當(dāng)前連接,也就是說別的連接的更新不會影響到當(dāng)前連接的取值.
這樣可能每個ID都得弄一張表來維護,這也是缺點.
具體使用中如何處理,就看自己的選擇了.
《Mysql入門利用mysql事務(wù)特性實現(xiàn)并發(fā)安全的自增ID示例》是否對您有啟發(fā),歡迎查看更多與《Mysql入門利用mysql事務(wù)特性實現(xiàn)并發(fā)安全的自增ID示例》相關(guān)教程,學(xué)精學(xué)透。維易PHP學(xué)院為您提供精彩教程。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/13984.html