如何在C#項目中安裝與使用SQLite?針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
江干ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!
SQLite 介紹
SQLite,是一款輕型的數(shù)據(jù)庫,用于本地的數(shù)據(jù)儲存。
先說說優(yōu)點,它占用資源非常的低,在嵌入式設(shè)備中需要幾百K的內(nèi)存就夠了;作為輕量級數(shù)據(jù)庫,他的處理速度也足夠快;支持的的容量級別為T級;獨立: 沒有額外依賴;開源;支持多種語言;
我的用途
在項目開發(fā)中,需要做一次數(shù)據(jù)數(shù)據(jù)同步。因為數(shù)據(jù)庫實時數(shù)據(jù)的同步,需要記錄更新時間,系統(tǒng)日志等等數(shù)據(jù);當然,你也可以選擇寫ini和xml等等配置文件來解決,但是都如數(shù)據(jù)庫可讀性高不是。
安裝
1. 引用 .NET 驅(qū)動 http://system.data.sqlite.org/index.html/doc/trunk/www/index.wiki
這三個文件,在項目中,引用之后就可以進行創(chuàng)建數(shù)據(jù)庫查詢數(shù)據(jù)操作。
2.使用vs提供的包管理工具Nuget進行項目引用。
Nuget包管理工具
搜索SQLite安裝對應(yīng)的包,下載完成后就自動在項目中引用了。
使用
創(chuàng)建數(shù)據(jù)庫
//創(chuàng)建一個數(shù)據(jù)庫 SQLiteConnection.CreateFile("Database.sqlite");
操作數(shù)據(jù)庫
//創(chuàng)建連接字符串 SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;"); //這是數(shù)據(jù)庫登錄密碼 conn.SetPassword("1234"); //打開數(shù)據(jù)庫 conn.Open(); string query = "create table table1 (id INTEGER, name VARCHAR)"; //創(chuàng)建命令 SQLiteCommand cmd = new SQLiteCommand(query, conn); //執(zhí)行命令 cmd.ExecuteNonQuery(); //釋放資源 conn.Close();
插入數(shù)據(jù)
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();
查詢數(shù)據(jù)
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
連接數(shù)據(jù)庫
查表
設(shè)置主鍵,已經(jīng)自增。
主鍵自增類型必須是 INTEGER類型
其他
1.SQLite .NET驅(qū)動設(shè)置數(shù)據(jù)庫讀取密碼
.net驅(qū)動之中,提供了單獨設(shè)置密碼和登錄密碼
using (SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;")) { conn.Open(); //設(shè)置數(shù)據(jù)庫密碼 conn.ChangePassword("123456"); conn.Clone(); }
登錄帶密碼的數(shù)據(jù)庫
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(); }
密碼正確查詢成功
密碼錯誤查詢異常
還有就是密碼設(shè)置錯誤,打開數(shù)據(jù)庫后數(shù)據(jù)庫狀態(tài)依舊是打開狀態(tài),但是查詢后出現(xiàn)異常無法查詢。
使用 dotnet驅(qū)動設(shè)置密碼之后,使用其他框架驅(qū)動貌似就無法打開了。
FQA
1.大量數(shù)據(jù)頻繁Insert特別慢怎么辦?
解決辦法是使用事務(wù)來Insert數(shù)據(jù).
SQLite給出的解釋是:正常執(zhí)行Insert,每一次執(zhí)行都占用一次IO,而使用事務(wù)執(zhí)行,直到Insert結(jié)束只占用一次IO;
執(zhí)行事務(wù)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; }
關(guān)于如何在C#項目中安裝與使用SQLite問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。
當前名稱:如何在C#項目中安裝與使用SQLite
新聞來源:http://m.newbst.com/article30/pjdepo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、Google、品牌網(wǎng)站建設(shè)、手機網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計、搜索引擎優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)