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安裝對應的包,下載完成后就自動在項目中引用了。
使用
創建數據庫
 //創建一個數據庫 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;}總結
以上所述是小編給大家介紹的SQLite在C#中的安裝與操作技巧,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
新聞熱點
疑難解答