久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

SQLite中多個應用程序是否可以同時訪問單個數(shù)據(jù)庫文件嗎

165次閱讀
沒有評論

共計 948 個字符,預計需要花費 3 分鐘才能閱讀完成。

本篇文章為大家展示了 SQLite 中多個應用程序是否可以同時訪問單個數(shù)據(jù)庫文件嗎,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

多個進程可以同時打開同一個數(shù)據(jù)庫。多個進程可以同時執(zhí)行 SELECT。但是,只有一個進程可以隨時對數(shù)據(jù)庫進行更改。

SQLite 使用讀 / 寫鎖來控制對數(shù)據(jù)庫的訪問。(在 Win95 / 98 /  ME 下,缺少對讀寫鎖的支持,而是使用概率模擬。)但請注意:如果數(shù)據(jù)庫文件保存在 NFS 文件系統(tǒng)上,則此鎖定機制可能無法正常工作。這是因為許多 NFS 實現(xiàn)都會破壞 fcntl()文件鎖定。如果多個進程可能同時嘗試訪問該文件,則應避免將 SQLite 數(shù)據(jù)庫文件放在 NFS 上。在 Windows 上,Microsoft 的文檔說如果您沒有運行 Share.exe 守護程序,則在 FAT 文件系統(tǒng)下鎖定可能不起作用。對 Windows 有很多經(jīng)驗的人告訴我,網(wǎng)絡文件的文件鎖定是非常錯誤的,并且不可靠。

我們知道沒有其他嵌入式  SQL 數(shù)據(jù)庫引擎支持與 SQLite 一樣多的并發(fā)性。SQLite 允許多個進程一次打開數(shù)據(jù)庫文件,并允許多個進程一次讀取數(shù)據(jù)庫。當任何進程想要寫入時,它必須在更新期間鎖定整個數(shù)據(jù)庫文件。但這通常只需要幾毫秒。其他流程只是等待作者完成然后繼續(xù)他們的業(yè)務。其他嵌入式 SQL 數(shù)據(jù)庫引擎通常只允許單個進程一次連接到數(shù)據(jù)庫。

但是,客戶端 / 服務器數(shù)據(jù)庫引擎 (如 PostgreSQL,MySQL 或 Oracle) 通常支持更高級別的并發(fā)性,并允許多個進程同時寫入同一數(shù)據(jù)庫。這在客戶端 / 服務器數(shù)據(jù)庫中是可能的,因為總有一個良好控制的服務器進程可用于協(xié)調(diào)訪問。如果您的應用程序需要大量并發(fā),那么您應該考慮使用客戶端 / 服務器數(shù)據(jù)庫。但經(jīng)驗表明,大多數(shù)應用程序需要的并發(fā)性遠低于設計人員的想象。

當 SQLite 嘗試訪問由另一個進程鎖定的文件時,默認行為是返回 SQLITE_BUSY。您可以使用 sqlite3_busy_handler()或 sqlite3_busy_timeout()  API 函數(shù)從 C 代碼調(diào)整此行為。

上述內(nèi)容就是 SQLite 中多個應用程序是否可以同時訪問單個數(shù)據(jù)庫文件嗎,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道。

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-07-18發(fā)表,共計948字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 温州市| 崇义县| 皋兰县| 株洲县| 卫辉市| 缙云县| 淮安市| 集贤县| 闵行区| 师宗县| 鞍山市| 芒康县| 开封市| 恩施市| 嘉兴市| 遂昌县| 禄丰县| 清镇市| 双辽市| 维西| 五寨县| 晴隆县| 宣威市| 通州区| 林芝县| 资源县| 平武县| 德令哈市| 乡城县| 清流县| 南皮县| 曲靖市| 山阳县| 科技| 临汾市| 乌鲁木齐县| 通许县| 青神县| 蛟河市| 昌图县| 罗平县|