GRDB使用SQLite的WAL模式

來源:互聯網
上載者:User

標籤:llb   工作   影響   修改   epo   logging   head   檔案名稱   建立   

GRDB使用SQLite的WAL模式 WAL全稱是Write Ahead Logging,它是SQLite中實現原子事務的一種機制。該模式是從SQLite 3.7.0版本引入的。再此之前,SQLite使用Rollback Journal機制實現原子事務。在Rollback Journal機制中,當需要修改資料時,先把被修改的資料備份出來,然後把資料庫的資料修改。如果事務成功,就把備份資料刪掉;如果事務失敗,則恢複備份資料。這個機制的缺點是讀寫頻繁,並且寫的時候,不能讀取。 而WAL模式的工作機制如同其名稱一樣,在寫入資料庫之前,先寫入一個記錄檔。這個記錄檔名為wal的檔案。當事務成功,修改的內容會保留在這個檔案中。當事務失敗,則從這個檔案中刪除。當wal檔案的記錄積累到一定數量,則一次性寫入資料庫中。如果讀取資料庫,則先從wal中讀取,然後再讀取資料庫檔案。這樣,寫操作不會影響讀操作,從而提高效率。 GRDB直接支援WAL模式。當開發人員使用DatabasePool建立資料庫連接,則預設使用WAL模式;如果使用DatabaseQueue建立串連,則不使用該模式。如果WAL中的積累資料太多時候,寫入資料庫會造成資料庫效能下降,所以避免WAL積累資料太多。

GRDB使用SQLite的WAL模式

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.