redis中的事務(wù)操作案例分析
本文實(shí)例講述了redis中的事務(wù)操作。分享給大家供大家參考,具體如下:
redis與mysql的事務(wù)
Redis支持簡(jiǎn)單的事務(wù)
簡(jiǎn)單使用
講張三的100圓錢(qián)轉(zhuǎn)賬給lisi:
set zhangsan 800 set lisi 100 multi decrby zhangsan 100 incrby lisi 100 exec
失敗的兩種情況
在mutil后面的語(yǔ)句中, 語(yǔ)句出錯(cuò)可能有2種情況,還是以轉(zhuǎn)賬的情況來(lái)分析:
(1)語(yǔ)法就有問(wèn)題
127.0.0.1:6379> multi OK 127.0.0.1:6379> decrby zhang 100 QUEUED 127.0.0.1:6379> hasdfasdf (error) ERR unknown command 'hasdfasdf' 127.0.0.1:6379> exec (error) EXECABORT Transaction discarded because of previous errors. 127.0.0.1:6379> mget zhang wang 1) "800" 2) "100"
這種,exec時(shí),報(bào)錯(cuò), 所有語(yǔ)句得不到執(zhí)行,所以還是800和100圓
(2)語(yǔ)法本身沒(méi)錯(cuò),但適用對(duì)象有問(wèn)題
127.0.0.1:6379> multi OK 127.0.0.1:6379> decrby zhang 100 QUEUED 127.0.0.1:6379> sadd wang 1 QUEUED 127.0.0.1:6379> exec 1) (integer) 700 2) (error) WRONGTYPE Operation against a key holding the wrong kind of value 127.0.0.1:6379> mget zhang wang 1) "700" 2) "100"
Exec之后,會(huì)執(zhí)行正確的語(yǔ)句,并跳過(guò)有不適當(dāng)?shù)恼Z(yǔ)句,所以這里是一個(gè)700圓一個(gè)100圓了
案例
假設(shè)買(mǎi)票案例,當(dāng)前只有1張票和100塊錢(qián),如果我在買(mǎi)票的過(guò)程中,在我multi之后,和exec之前,票被別人買(mǎi)了—即ticket已經(jīng)變成0了,然后我們執(zhí)行exec的時(shí)候就會(huì)將票變?yōu)?1,這就不對(duì)了。
127.0.0.1:6379> set ticket 1 OK 127.0.0.1:6379> set money 100 OK 127.0.0.1:6379> multi OK 127.0.0.1:6379> decr ticket QUEUED 127.0.0.1:6379> decrby money 10 QUEUED 127.0.0.1:6379> exec 1) (integer) -1 2) (integer) 90
使用watch來(lái)檢測(cè)票有沒(méi)有被買(mǎi)走
實(shí)用watch
來(lái)檢測(cè)指定的key,負(fù)責(zé)監(jiān)測(cè)key沒(méi)有被改動(dòng)。
127.0.0.1:6379> set ticket 1 OK 127.0.0.1:6379> set money 100 OK 127.0.0.1:6379> watch ticket OK 127.0.0.1:6379> multi OK 127.0.0.1:6379> decr ticket QUEUED 127.0.0.1:6379> decrby money 10 QUEUED 127.0.0.1:6379> exec (nil)//返回nil,說(shuō)明監(jiān)視的ticket已經(jīng)改變了,事務(wù)就取消了. 127.0.0.1:6379> mget ticket money 1) "0" 2) "100"
在執(zhí)行exec之前,票被買(mǎi)走了,ticket為0了,然后執(zhí)行exec后,發(fā)現(xiàn)ticket被動(dòng)了,所以就不執(zhí)行事務(wù)了,事務(wù)被取消了。在執(zhí)行exec的時(shí)候返回nil
。
watch相關(guān)用法
watch key1 key2 ... keyN
作用:監(jiān)聽(tīng)key1 key2..keyN有沒(méi)有變化,如果有變, 則事務(wù)取消
unwatch
作用:取消所有watch監(jiān)聽(tīng)
希望本文所述對(duì)大家Redis數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。
相關(guān)文章
Redis分布式鎖的使用和實(shí)現(xiàn)原理詳解
這篇文章主要給大家介紹了關(guān)于Redis分布式鎖的使用和實(shí)現(xiàn)原理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11Redis實(shí)現(xiàn)庫(kù)存扣減的解決方案防止商品超賣(mài)
在日常開(kāi)發(fā)中有很多地方都有類(lèi)似扣減庫(kù)存的操作,比如電商系統(tǒng)中的商品庫(kù)存,抽獎(jiǎng)系統(tǒng)中的獎(jiǎng)品庫(kù)存等,基于redis實(shí)現(xiàn)扣減庫(kù)存的具體實(shí)現(xiàn),初始化庫(kù)存回調(diào)函數(shù)(IStockCallback)扣減庫(kù)存服務(wù)(StockService),感興趣的朋友跟隨小編一起看看吧2022-06-06Redis高并發(fā)場(chǎng)景下秒殺超賣(mài)解決方案(秒殺場(chǎng)景)
早起的12306購(gòu)票,剛被開(kāi)發(fā)出來(lái)使用的時(shí)候,12306會(huì)經(jīng)常出現(xiàn)超賣(mài) 這種現(xiàn)象,也就是說(shuō)車(chē)票只剩10張了,卻被20個(gè)人買(mǎi)到了,這種現(xiàn)象就是超賣(mài),今天通過(guò)本文給大家介紹Redis高并發(fā)場(chǎng)景下秒殺超賣(mài)解決方案,感興趣的朋友一起看看吧2022-04-04Redis配置文件redis.conf詳細(xì)配置說(shuō)明
本文列出了Redis的配置文件redis.conf的各配置項(xiàng)的詳細(xì)說(shuō)明,簡(jiǎn)單易懂2018-03-03redis簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了redis簡(jiǎn)介,Redis是一個(gè)開(kāi)源的,先進(jìn)的 key-value 存儲(chǔ)可用于構(gòu)建高性能,可擴(kuò)展的 Web 應(yīng)用程序的解決方案,有興趣的可以了解一下2017-08-08