您好,登錄后才能下訂單哦!
本篇文章為大家展示了SQLite中多個(gè)應(yīng)用程序是否可以同時(shí)訪問單個(gè)數(shù)據(jù)庫文件嗎,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
多個(gè)進(jìn)程可以同時(shí)打開同一個(gè)數(shù)據(jù)庫。多個(gè)進(jìn)程可以同時(shí)執(zhí)行SELECT。但是,只有一個(gè)進(jìn)程可以隨時(shí)對(duì)數(shù)據(jù)庫進(jìn)行更改。
SQLite使用讀/寫鎖來控制對(duì)數(shù)據(jù)庫的訪問。(在Win95 / 98 / ME下,缺少對(duì)讀寫鎖的支持,而是使用概率模擬。)但請(qǐng)注意:如果數(shù)據(jù)庫文件保存在NFS文件系統(tǒng)上,則此鎖定機(jī)制可能無法正常工作。這是因?yàn)樵S多NFS實(shí)現(xiàn)都會(huì)破壞fcntl()文件鎖定。如果多個(gè)進(jìn)程可能同時(shí)嘗試訪問該文件,則應(yīng)避免將SQLite數(shù)據(jù)庫文件放在NFS上。在Windows上,Microsoft的文檔說如果您沒有運(yùn)行Share.exe守護(hù)程序,則在FAT文件系統(tǒng)下鎖定可能不起作用。對(duì)Windows有很多經(jīng)驗(yàn)的人告訴我,網(wǎng)絡(luò)文件的文件鎖定是非常錯(cuò)誤的,并且不可靠。
我們知道沒有其他嵌入式 SQL數(shù)據(jù)庫引擎支持與SQLite一樣多的并發(fā)性。SQLite允許多個(gè)進(jìn)程一次打開數(shù)據(jù)庫文件,并允許多個(gè)進(jìn)程一次讀取數(shù)據(jù)庫。當(dāng)任何進(jìn)程想要寫入時(shí),它必須在更新期間鎖定整個(gè)數(shù)據(jù)庫文件。但這通常只需要幾毫秒。其他流程只是等待作者完成然后繼續(xù)他們的業(yè)務(wù)。其他嵌入式SQL數(shù)據(jù)庫引擎通常只允許單個(gè)進(jìn)程一次連接到數(shù)據(jù)庫。
但是,客戶端/服務(wù)器數(shù)據(jù)庫引擎(如PostgreSQL,MySQL或Oracle)通常支持更高級(jí)別的并發(fā)性,并允許多個(gè)進(jìn)程同時(shí)寫入同一數(shù)據(jù)庫。這在客戶端/服務(wù)器數(shù)據(jù)庫中是可能的,因?yàn)榭傆幸粋€(gè)良好控制的服務(wù)器進(jìn)程可用于協(xié)調(diào)訪問。如果您的應(yīng)用程序需要大量并發(fā),那么您應(yīng)該考慮使用客戶端/服務(wù)器數(shù)據(jù)庫。但經(jīng)驗(yàn)表明,大多數(shù)應(yīng)用程序需要的并發(fā)性遠(yuǎn)低于設(shè)計(jì)人員的想象。
當(dāng)SQLite嘗試訪問由另一個(gè)進(jìn)程鎖定的文件時(shí),默認(rèn)行為是返回SQLITE_BUSY。您可以使用sqlite3_busy_handler()或sqlite3_busy_timeout() API函數(shù)從C代碼調(diào)整此行為 。
上述內(nèi)容就是SQLite中多個(gè)應(yīng)用程序是否可以同時(shí)訪問單個(gè)數(shù)據(jù)庫文件嗎,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。