使用C# 壓縮 SQLite 資料庫注意事項

來源:互聯網
上載者:User

標籤:

當從SQLite資料庫中刪除了大量資料,如果探索資料庫檔案並未變小,可以執行 VACUUM 命令,該命令將重新組織資料庫,釋放多餘空間。

測試插入資料

                try                {                    SQLiteConnection cnn = new SQLiteConnection(@"Data Source=G:\App_Data\Data.sqlite;");                    cnn.Open();                    using (SQLiteTransaction dbTrans = cnn.BeginTransaction())                    {                        using (SQLiteCommand cmd = cnn.CreateCommand())                        {                            try                            {                                cmd.CommandText = @"INSERT INTO Students (Name, Description) VALUES   (‘1‘, ‘2‘)";                                for (int n = 0; n < 100000; n++)                                {                                    cmd.ExecuteNonQuery();                                }                                dbTrans.Commit();                            }                            catch                            {                                dbTrans.Rollback();                            }                        }                    }                }                catch (Exception ex)                {                    Clipboard.SetText(ex.Message + "\r\n\r\n" + ex.StackTrace);                }

 

刪除表中的資料後,探索資料庫檔案並未變小。

執行以下操作:

            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();                    }                }            }

 探索資料庫檔案變為2kb。

注意壓縮資料庫執行操作中,不要使用Transaction事務,否則會失敗。

 

使用C# 壓縮 SQLite 資料庫注意事項

相關文章

聯繫我們

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