SQLite在C#中的安裝與操作


SQLite 介紹

SQLite,是一款輕型的數據庫,用於本地的數據儲存。

先說說優點,它占用資源非常的低,在嵌入式設備中需要幾百K的內存就夠了;作為輕量級數據庫,他的處理速度也足夠快;支持的的容量級別為T級;獨立: 沒有額外依賴;開源;支持多種語言;

我的用途

在項目開發中,需要做一次數據數據同步。因為數據庫實時數據的同步,需要記錄更新時間,系統日志等等數據;當然,你也可以選擇寫ini和xml等等配置文件來解決,但是都如數據庫可讀性高不是。

安裝

1. 引用 .NET 驅動 http://system.data.sqlite.org/index.html/doc/trunk/www/index.wiki

 

這三個文件,在項目中,引用之后就可以進行創建數據庫查詢數據操作。

 

2.使用vs提供的包管理工具Nuget進行項目引用。

Nuget包管理工具

搜索SQLite安裝對應的包,下載完成后就自動在項目中引用了。

使用

創建數據庫

 

1 //創建一個數據庫
2 SQLiteConnection.CreateFile("Database.sqlite");

 

操作數據庫

//創建連接字符串
SQLiteConnection  conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;");
//這是數據庫登錄密碼
conn.SetPassword("1234");
//打開數據庫
conn.Open();
string query = "create table table1 (id INTEGER, name VARCHAR)";
//創建命令
SQLiteCommand cmd = new SQLiteCommand(query, conn);
//執行命令
cmd.ExecuteNonQuery();
//釋放資源
conn.Close();

插入數據

SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;");
conn.Open();
string query = "insert into table1 (id,name) values(1,'小明')";
SQLiteCommand cmd = new SQLiteCommand(query, conn);
cmd.ExecuteNonQuery();
conn.Close();
cmd.Dispose();

查詢數據

using (SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;"))
{
    conn.Open();
    string query = "select * from table1";
    SQLiteCommand cmd = new SQLiteCommand(query, conn);
    SQLiteDataAdapter da = new SQLiteDataAdapter(cmd);
    DataTable dt = new DataTable();
    da.Fill(dt);
}

 

可視化工具

 SQLiteStudio 可視化工具    https://sqlitestudio.pl

 

連接數據庫

查表

設置主鍵,已經自增。

主鍵自增類型必須是 INTEGER類型

 

其他

1.SQLite .NET驅動設置數據庫讀取密碼

.net驅動之中,提供了單獨設置密碼和登錄密碼

using (SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;"))
{
    conn.Open();
    //設置數據庫密碼
    conn.ChangePassword("123456");
    conn.Clone();
}

登錄帶密碼的數據庫

using (SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;"))
{
    conn.SetPassword("123456");
    conn.Open();
    string query = "select * from table1";
    SQLiteCommand cmd = new SQLiteCommand(query, conn);
    SQLiteDataAdapter da = new SQLiteDataAdapter(cmd);
    DataTable dt = new DataTable();
    da.Fill(dt);
    conn.Clone();
}

密碼正確查詢成功

密碼錯誤查詢異常

還有就是密碼設置錯誤,打開數據庫后數據庫狀態依舊是打開狀態,但是查詢后出現異常無法查詢。

使用 dotnet驅動設置密碼之后,使用其他框架驅動貌似就無法打開了。

FQA

1.大量數據頻繁Insert特別慢怎么辦?

  解決辦法是使用事務來Insert數據.

  SQLite給出的解釋是:正常執行Insert,每一次執行都占用一次IO,而使用事務執行,直到Insert結束只占用一次IO;

 執行事務Insert代碼

private bool QueryTran(List<string> queryList)
{
    SQLiteConnection conn = new SQLiteConnection("Data Source=DataBase;Version=3;");
    SQLiteCommand cmd = conn.CreateCommand();
    conn.Open();
    SQLiteTransaction tran = conn.BeginTransaction();
    bool check = false;
    try
    {
        foreach (string item in queryList)
        {
            cmd.CommandText = item;
            cmd.ExecuteNonQuery();
        }
        tran.Commit();
        check = true;
    }
    catch (Exception ex)
    {
        tran.Rollback();
        check = false;
        throw ex;
    }
    finally
    {
        conn.Close();
    }
    return check;
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM