SQLite 介紹 SQLite,是一款輕型的資料庫,用於本地的數據儲存。 先說說優點,它占用資源非常的低,在嵌入式設備中需要幾百K的記憶體就夠了;作為輕量級資料庫,他的處理速度也足夠快;支持的的容量級別為T級;獨立: 沒有額外依賴;開源;支持多種語言; 我的用途 在項目開發中,需要做一次數據數據同步 ...
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; }