欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

PostgreSQLDBA(81)-Locks(FORUPDATESKIPLOCKED)

本節(jié)介紹了PostgreSQL中的FOR UPDATE SKIP LOCKED,通過該Option可以提高某些場景下的并發(fā)性能.

成都創(chuàng)新互聯(lián)十余年專注成都高端網站建設按需求定制設計服務,為客戶提供專業(yè)的成都網站制作,成都網頁設計,成都網站設計服務;成都創(chuàng)新互聯(lián)服務內容包含成都網站建設,成都微信小程序,軟件開發(fā),網絡營銷推廣,網絡運營服務及企業(yè)形象設計;成都創(chuàng)新互聯(lián)擁有眾多專業(yè)的高端網站制作開發(fā)團隊,資深的高端網頁設計團隊及經驗豐富的架構師高端網站策劃團隊;我們始終堅持從客戶的角度出發(fā),為客戶量身訂造網絡營銷方案,解決網絡營銷疑問。

Session 1希望從tbl中id < 100的記錄中隨機選擇一行:


[local]:5432 pg12@testdb=# select pg_backend_pid();
 pg_backend_pid 
----------------
           1591
(1 row)
Time: 8.613 ms
[local]:5432 pg12@testdb=# begin;
BEGIN
Time: 4.527 ms
[local]:5432 pg12@testdb=#* select * from tbl where id in (1,2,3) limit 1 for update;
 id | c1  | c2  | c3  | c4 | c5 
----+-----+-----+-----+----+----
  1 | c11 | c21 | c31 |    | c3
(1 row)
Time: 1.450 ms
[local]:5432 pg12@testdb=#*

下面是該SQL的鎖信息


[local]:5432 pg12@testdb=# select pid,locktype,relation::regclass,mode,page,tuple,virtualxid,transactionid,virtualtransaction,granted,fastpath from pg_locks where relation='tbl'::regclass;
-[ RECORD 1 ]------+-------------
pid                | 1591
locktype           | relation
relation           | tbl
mode               | RowShareLock
page               | 
tuple              | 
virtualxid         | 
transactionid      | 
virtualtransaction | 3/2
granted            | t
fastpath           | t
Time: 1.627 ms

假如Session 2也是希望從id < 100的記錄中隨機選擇一行,但這時候會因為沖突而阻塞:


[local]:5432 pg12@testdb=# begin;
BEGIN
Time: 0.962 ms
[local]:5432 pg12@testdb=#* select * from tbl where id in (1,2,3) limit 1 for update;

相關鎖信息:


[local]:5432 pg12@testdb=# select pid,locktype,relation::regclass,mode,page,tuple,virtualxid,transactionid,virtualtransaction,granted,fastpath from pg_locks where relation='tbl'::regclass;
-[ RECORD 1 ]------+--------------------
pid                | 1634
locktype           | relation
relation           | tbl
mode               | RowShareLock
page               | 
tuple              | 
virtualxid         | 
transactionid      | 
virtualtransaction | 4/16
granted            | t
fastpath           | t
-[ RECORD 2 ]------+--------------------
pid                | 1591
locktype           | relation
relation           | tbl
mode               | RowShareLock
page               | 
tuple              | 
virtualxid         | 
transactionid      | 
virtualtransaction | 3/4
granted            | t
fastpath           | t
-[ RECORD 3 ]------+--------------------
pid                | 1634
locktype           | tuple
relation           | tbl
mode               | AccessExclusiveLock
page               | 0
tuple              | 1
virtualxid         | 
transactionid      | 
virtualtransaction | 4/16
granted            | t
fastpath           | f
Time: 1.276 ms

PostgreSQL提供FOR UPDATE SKIP LOCKED,在Session 2獲取一行時可跳過locked的行,從而提高并發(fā)性能


[local]:5432 pg12@testdb=#* select * from tbl where id in (1,2,3) limit 1 for update SKIP LOCKED;
 id | c1  | c2  | c3  | c4 | c5 
----+-----+-----+-----+----+----
  2 | c12 | c22 | c32 |    | c3
(1 row)
Time: 2.413 ms

可以看到,使用SKIP LOCKED選項,Session 2并沒有被阻塞而是獲取了沒有l(wèi)ocked的tuple.

這時候的鎖信息如下:


[local]:5432 pg12@testdb=# select pid,locktype,relation::regclass,mode,page,tuple,virtualxid,transactionid,virtualtransaction,granted,fastpath from pg_locks where relation='tbl'::regclass;
-[ RECORD 1 ]------+-------------
pid                | 1634
locktype           | relation
relation           | tbl
mode               | RowShareLock
page               | 
tuple              | 
virtualxid         | 
transactionid      | 
virtualtransaction | 4/17
granted            | t
fastpath           | t
-[ RECORD 2 ]------+-------------
pid                | 1591
locktype           | relation
relation           | tbl
mode               | RowShareLock
page               | 
tuple              | 
virtualxid         | 
transactionid      | 
virtualtransaction | 3/4
granted            | t
fastpath           | t
Time: 0.978 ms

參考資料
More concurrency: Improved locking in PostgreSQL

網頁標題:PostgreSQLDBA(81)-Locks(FORUPDATESKIPLOCKED)
地址分享:http://aaarwkj.com/article10/igcpgo.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供網站設計公司品牌網站設計、建站公司做網站、關鍵詞優(yōu)化、云服務器

廣告

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

成都網頁設計公司
国产成人综合亚洲乱淫.| 成人精品午夜福利视频| 日韩一级免费高清黄片| 国产综合中文字幕不卡| 高清区一区二区在线播放| 成人偷拍自拍在线视频| 日韩50岁老女人骚色| 日韩一区二区三区av| 亚洲天堂一区二区av| 国产精品久久av高潮呻吟| 亚洲一区日韩精品颜射| 国产精品久久久av大片| 国产av一区二区三区野战| 国产精品久久高清免费| 未满十八禁止免费在线观看| 国产一区二区精品性浆| 日韩精品毛片一区到三区| 青青草原在线免费视频| 国产免费成人在线视频| 免费在线观看成人av| 亚洲国产av永久精品成人| 欧美日韩国产另类一区二区| 男人一插就想射的原因| 91免费视频精品麻豆| 中文字幕乱码日韩在线| 日本成熟亚洲中文字幕的| 亚洲一区二区三区四区国产| 亚洲国产精品区一区二区| 日本一区二区不卡二区| 国产免费成人在线视频| 亚洲欧美一区二区国产| 婷婷国产综合一区二区三区| 黄色av手机在线观看| 久久久之久亚州精品露出| 国产三级国产精品国产国在线观看| 国产精品福利午夜在线| 熟妇人妻久久中文字幕麻豆网| 国产日本欧美一区二区三区| 色六月婷婷六月久久六月| 天天操操操操操操夜夜爽| 日韩av在线国产观看|