黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 為什么sqlite會(huì)返回database locked而別的數(shù)據(jù)庫(kù)不會(huì)?

為什么sqlite會(huì)返回database locked而別的數(shù)據(jù)庫(kù)不會(huì)?

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-10-13 15:53:23 1697183603

一、為什么sqlite會(huì)返回database locked而別的數(shù)據(jù)庫(kù)不會(huì)

sqlite可以支持多個(gè)進(jìn)程同時(shí)讀取,但不支持同時(shí)寫入,主要原因是因?yàn)樗J(rèn)采用了串行化的事務(wù)隔離,他在寫數(shù)據(jù)到文件的時(shí)候加了一把文件粒度的排他鎖,這個(gè)時(shí)候是不能并發(fā)讀取的和寫入的,這時(shí)如果有請(qǐng)求就會(huì)進(jìn)入等待。

等待超時(shí)后會(huì)拋出database is locked錯(cuò)誤。這個(gè)和嵌入式?jīng)]什么關(guān)系,嵌入式數(shù)據(jù)庫(kù)同樣可以通過文件鎖、共享內(nèi)存等方式實(shí)現(xiàn)多進(jìn)程訪問,通過快照隔離實(shí)現(xiàn)并發(fā)讀寫。

MySQL里面的myisam引擎其實(shí)也是不支持并發(fā)讀寫的,現(xiàn)在用的比較少,innodb存儲(chǔ)引擎則是通過MVCC支持并發(fā)讀寫的。

sqlite遇到database is locked問題的完美解決
1、使用進(jìn)程或線程間的同步機(jī)制以避免同時(shí)操作;如用信號(hào)量,互斥鎖等(pthread_mutex_lock,
pthread_mutex_unlock),如果你的項(xiàng)目工程較大要求較高的話建議用此方法自行封裝函數(shù)處理同步
2、使用sqlite提供的兩個(gè)busy handler函數(shù),但對(duì)于一個(gè)連接來說,只能有一個(gè)busy handle,兩個(gè)函數(shù)會(huì)相互影響,設(shè)
置一個(gè)的同時(shí)會(huì)清除另一個(gè),應(yīng)根據(jù)需要來選擇。
int sqlite3_busy_handler(sqlite3 *, int (*)(void *, int), void *)
不注冊(cè)此函數(shù)時(shí)默認(rèn)回調(diào)函數(shù)為NULL,清除busy handle,申請(qǐng)不到鎖直接返回;
函數(shù)可以定義一個(gè)回調(diào)函數(shù),當(dāng)出現(xiàn)數(shù)據(jù)庫(kù)忙時(shí)sqlite會(huì)調(diào)用該函數(shù)進(jìn)行延時(shí)并返回非0會(huì)重試本次操作,回調(diào)函數(shù)的第二個(gè)
參數(shù)會(huì)被傳遞為此次因BUSY忙事件而調(diào)用該函數(shù)的次數(shù),因此你完全可以自行控制多少次后(也就是延時(shí)多少后)才真正返回
BUSY;
回調(diào)函數(shù)返回非0,數(shù)據(jù)庫(kù)會(huì)重試當(dāng)前操作,返回0則當(dāng)前操作返回SQLITE_BUSY;
int sqlite3_busy_timeout(sqlite3*, int ms);
不注冊(cè)此函數(shù)時(shí)默認(rèn)超時(shí)等待為0,當(dāng)ms<=0時(shí),清除busy handle,申請(qǐng)不到鎖直接返回;
定義一個(gè)毫秒數(shù),當(dāng)未到達(dá)該毫秒數(shù)時(shí),sqlite會(huì)sleep并重試當(dāng)前操作,
如果超過ms毫秒,仍然申請(qǐng)不到需要的鎖,當(dāng)前操作返回SQLITE_BUSY;
很多人用這個(gè)函數(shù)沒有成功,其實(shí)只要你仔細(xì)查看sqlite的源碼就會(huì)發(fā)現(xiàn),
這個(gè)函數(shù)實(shí)際上注冊(cè)了一個(gè)默認(rèn)的sqlite3_busy_handler(sqliteDefaultBusyCallback),而這個(gè)回調(diào)函數(shù)在你的編譯
環(huán)境下可能使得第二個(gè)ms參數(shù)必需要大于1000且是他的整數(shù)倍才有意義,由于此默認(rèn)callback函數(shù)延時(shí)較大,建議自己寫回
調(diào)函數(shù)然后用slite3_busy_handler注冊(cè),這樣就可以自己用自己的延時(shí)函數(shù)或方法進(jìn)行處理了。

延伸閱讀:

二、SQL是什么

Structured Query Language

‘SQL’是結(jié)構(gòu)化查詢語(yǔ)言,是一種用來操作?RDBMS?的數(shù)據(jù)庫(kù)語(yǔ)言,當(dāng)前關(guān)系型數(shù)據(jù)庫(kù)都支持使用SQL語(yǔ)言進(jìn)行操作,也就是說可以通過?SQL?操作 oracle,sql server,mysql,sqlite 等等所有的關(guān)系型的數(shù)據(jù)庫(kù)

SQL語(yǔ)句主要分為:
DQL:數(shù)據(jù)查詢語(yǔ)言,用于對(duì)數(shù)據(jù)進(jìn)行查詢,如select**
DML:數(shù)據(jù)操作語(yǔ)言,對(duì)數(shù)據(jù)進(jìn)行增加、修改、刪除,如insert、udpate、delete**
TPL:事務(wù)處理語(yǔ)言,對(duì)事務(wù)進(jìn)行處理,包括begin transaction、commit、rollback
DCL:數(shù)據(jù)控制語(yǔ)言,進(jìn)行授權(quán)與權(quán)限回收,如grant、revoke
DDL:數(shù)據(jù)定義語(yǔ)言,進(jìn)行數(shù)據(jù)庫(kù)、表的管理等,如create、drop
CCL:指針控制語(yǔ)言,通過控制指針完成表的操作,如declare cursor對(duì)于web程序員來講,重點(diǎn)是數(shù)據(jù)的crud(增刪改查),必須熟練編寫DQL、DML,能夠編寫DDL完成數(shù)據(jù)庫(kù)、表的操作,其它語(yǔ)言如TPL、DCL、CCL了解即可SQL 是一門特殊的語(yǔ)言,專門用來操作關(guān)系數(shù)據(jù)庫(kù)不區(qū)分大小寫
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
mysql.sock文件是怎么起作用的?

一、mysql.sock文件的工作原理在MySQL中,mysql.sock文件是用于實(shí)現(xiàn)本地套接字(socket)連接的一種機(jī)制。它在Unix或類Unix系統(tǒng)上使用,允許客...詳情>>

2023-10-13 17:39:11
oracle為什么要繼續(xù)開發(fā)mysql?

一、oracle為什么要繼續(xù)開發(fā)mysql應(yīng)該是之前收購(gòu)的時(shí)候有協(xié)議吧,而且,本身面向的客戶也不太一樣。oracle也有不付費(fèi)的用戶,mysql有社區(qū)版,但...詳情>>

2023-10-13 17:27:29
低代碼平臺(tái)的開發(fā),數(shù)據(jù)庫(kù)是怎么選擇的?

一、低代碼平臺(tái)的開發(fā),數(shù)據(jù)庫(kù)是怎么選擇的如果你選擇的低代碼開發(fā)平臺(tái)支持多種數(shù)據(jù)庫(kù),那就選你最熟悉的吧。除了oracle這種賊貴的,和postgres...詳情>>

2023-10-13 17:25:32
MySQL本地事務(wù)和MySQL XA事務(wù)的區(qū)別是什么?

一、MySQL本地事務(wù)和MySQL XA事務(wù)的區(qū)別MySQL本地事務(wù)是指在單個(gè)數(shù)據(jù)庫(kù)連接上執(zhí)行的事務(wù)操作,通常用于單個(gè)數(shù)據(jù)庫(kù)實(shí)例上的事務(wù)處理。它遵循數(shù)據(jù)...詳情>>

2023-10-13 17:16:58
foxmail 7.2使用的是什么方式存儲(chǔ)的郵件?

一、foxmail 7.2使用的是什么方式存儲(chǔ)的郵件1、foxmail郵件存儲(chǔ)位置在大家的安裝目錄下,我們可以直接右擊foxmail圖標(biāo)然后我們點(diǎn)擊“打開文件位...詳情>>

2023-10-13 17:08:36
快速通道
亚洲精品久久玖玖玖玖| 成人免费一级毛片在线播放视频| 国产不卡高清在线观看视频| 日韩在线观看网站| 日本特黄特黄aaaaa大片| 日韩中文字幕一区| 国产福利免费视频| 黄色免费三级| 亚洲 男人 天堂| 国产福利免费观看| 国产精品免费精品自在线观看| 韩国三级香港三级日本三级| 日韩一级精品视频在线观看| 美女免费黄网站| 午夜激情视频在线观看| 亚洲第一色在线| 日日日夜夜操| 久草免费在线观看| 精品国产香蕉伊思人在线又爽又黄| 色综合久久久久综合体桃花网| 精品久久久久久中文字幕一区| 九九久久国产精品| 中文字幕一区二区三区精彩视频| 久久国产精品自由自在| 欧美1卡一卡二卡三新区| 天天色成人| 欧美电影免费| 韩国三级香港三级日本三级| 精品久久久久久中文字幕一区 | 国产视频久久久久| 一级女人毛片人一女人| 黄色免费网站在线| 99色视频| 久久成人综合网| 久久福利影视| 精品国产三级a∨在线观看| 免费国产在线视频| 欧美激情一区二区三区视频| 中文字幕一区二区三区精彩视频| 亚久久伊人精品青青草原2020| 国产91视频网| 亚欧乱色一区二区三区| 人人干人人草| 91麻豆tv| 欧美激情一区二区三区在线| 国产视频久久久| 日韩在线观看视频网站| 精品视频在线观看一区二区| 国产麻豆精品免费视频| 欧美另类videosbestsex久久| 日本在线不卡免费视频一区| 精品毛片视频| 国产成人精品综合久久久| 成人免费观看网欧美片| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 色综合久久天天综线观看| 韩国毛片 免费| 日韩一级精品视频在线观看| 日本免费乱理伦片在线观看2018| 国产视频一区二区在线播放| 国产麻豆精品免费视频| 成人影院一区二区三区| 国产精品自拍在线观看| 你懂的国产精品| 成人高清护士在线播放| 欧美电影免费看大全| 黄视频网站在线看| 97视频免费在线| 国产网站免费| 韩国毛片 免费| 国产亚洲免费观看| 成人高清视频在线观看| 麻豆系列国产剧在线观看| 国产综合成人观看在线| 国产一区二区精品| 韩国三级香港三级日本三级| 黄视频网站在线看| 午夜欧美成人久久久久久| 久久99这里只有精品国产| 中文字幕一区二区三区精彩视频 | 欧美国产日韩一区二区三区| 成人免费福利片在线观看| 四虎影视库国产精品一区| 欧美另类videosbestsex| 精品久久久久久中文| 欧美另类videosbestsex高清| 九九热国产视频| 日本特黄特黄aaaaa大片| 亚洲女初尝黑人巨高清在线观看| 午夜欧美福利| 国产91精品系列在线观看| 亚洲精品影院| 亚洲天堂免费观看| 日韩综合| 精品国产亚洲人成在线| 国产一区二区福利久久| 超级乱淫黄漫画免费| 精品国产三级a| 国产成+人+综合+亚洲不卡| 美女免费精品视频在线观看| 青青久久精品| 免费国产在线观看不卡| 欧美另类videosbestsex视频| 国产91精品一区二区| 国产一区二区精品久久| 四虎精品在线观看| 午夜家庭影院| 青青久在线视频| 在线观看成人网 | 亚洲爆爽| 国产一区二区高清视频| 成人免费网站久久久| 国产亚洲免费观看| 日韩欧美一及在线播放| 日日日夜夜操| 黄色福利| 免费国产在线观看| 99色视频| 国产不卡高清| 青青久久网| 国产91精品系列在线观看| 精品久久久久久中文| 亚洲天堂免费| 国产伦理精品| 国产视频一区二区三区四区 | 青青青草影院| 久久久成人网| 午夜在线亚洲| 在线观看成人网| 国产精品自拍在线观看| 日本在线不卡视频| 久久99这里只有精品国产| 欧美a级片免费看| 999精品在线| 韩国毛片基地| 日韩一级黄色| 一 级 黄 中国色 片| 黄色福利片| 午夜激情视频在线观看| 二级片在线观看| 精品久久久久久影院免费| 尤物视频网站在线| 韩国毛片免费大片| 日韩av东京社区男人的天堂| 欧美电影免费| 日本在线不卡免费视频一区| 欧美一级视频免费| 黄色免费三级| 国产网站免费视频| 国产成a人片在线观看视频| 久久99欧美| 国产视频一区在线| 久久99中文字幕| 欧美激情一区二区三区在线播放 | 欧美国产日韩在线| 高清一级片| 欧美另类videosbestsex| 国产麻豆精品免费密入口| 沈樵在线观看福利| 精品国产三级a| 国产91素人搭讪系列天堂| 久久国产精品永久免费网站| 九九久久99综合一区二区| 国产精品免费精品自在线观看| 国产精品自拍在线观看| 成人免费高清视频| 午夜激情视频在线播放| 日本免费乱理伦片在线观看2018| 91麻豆高清国产在线播放| 日韩一级精品视频在线观看| 天堂网中文在线| 欧美爱色| 台湾毛片| 日韩在线观看视频黄| 久久精品店| 中文字幕一区二区三区精彩视频 | 日韩男人天堂| 免费一级生活片| 国产91视频网| 精品在线观看一区| 欧美激情一区二区三区在线| 999久久66久6只有精品| 999精品在线| 毛片电影网| 999精品在线| 国产91视频网| 日韩在线观看网站| 你懂的国产精品| 国产一区二区精品久久| 日本特黄特色aaa大片免费| 国产精品自拍在线| 国产不卡在线看| 黄色福利| 一级女性全黄生活片免费| 国产亚洲男人的天堂在线观看| 国产极品精频在线观看| 青青青草视频在线观看| 国产不卡高清| 欧美激情在线精品video| 黄视频网站在线免费观看|