C# 壓縮 SQLite 資料庫

來源:互聯網
上載者:User
當從SQLite資料庫中刪除資料時, 未用的磁碟空間將會加入一個內部的“自由列表”中。 當你下次插入資料時,這部分空間可以重用。磁碟空間不會丟失, 但也不會返還給作業系統。 

如果刪除了大量資料,而又想縮小資料庫檔案佔用的空間,執行 VACUUM 命令。 VACUUM
將會從頭重新組織資料庫。這將會使用資料庫有一個空的“自由鏈表”, 資料庫檔案也會最小。但要注意的是,VACUUM 的執行會需要一些時間
(在SQLite開發時,在Linux上,大約每M位元組需要半秒種),並且, 執行過程中需要原資料庫檔案至多兩倍的臨時磁碟空間。

 

/// <summary>        /// 執行壓縮資料庫        /// </summary>        /// <returns>壓縮資料庫</returns>        public static void ExecuteZip()        {            using (SQLiteConnection connection = new SQLiteConnection(connectionString))            {                using (SQLiteCommand cmd = new SQLiteCommand("VACUUM", connection))                {                    try                    {                        connection.Open();                        cmd.ExecuteNonQuery();                    }                    catch (System.Data.SQLite.SQLiteException E)                    {                        connection.Close();                        log.Debug( E.Message);                        //throw new Exception(E.Message);                    }                }            }        }

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.