SQLite在C#中的安裝與操作技巧
SQLite 介紹
SQLite,是一款輕型的數(shù)據(jù)庫(kù),用于本地的數(shù)據(jù)儲(chǔ)存。
先說(shuō)說(shuō)優(yōu)點(diǎn),它占用資源非常的低,在嵌入式設(shè)備中需要幾百K的內(nèi)存就夠了;作為輕量級(jí)數(shù)據(jù)庫(kù),他的處理速度也足夠快;支持的的容量級(jí)別為T級(jí);獨(dú)立: 沒有額外依賴;開源;支持多種語(yǔ)言;
我的用途
在項(xiàng)目開發(fā)中,需要做一次數(shù)據(jù)數(shù)據(jù)同步。因?yàn)閿?shù)據(jù)庫(kù)實(shí)時(shí)數(shù)據(jù)的同步,需要記錄更新時(shí)間,系統(tǒng)日志等等數(shù)據(jù);當(dāng)然,你也可以選擇寫ini和xml等等配置文件來(lái)解決,但是都如數(shù)據(jù)庫(kù)可讀性高不是。
安裝
1. 引用 .NET 驅(qū)動(dòng) http://system.data.sqlite.org/index.html/doc/trunk/www/index.wiki

這三個(gè)文件,在項(xiàng)目中,引用之后就可以進(jìn)行創(chuàng)建數(shù)據(jù)庫(kù)查詢數(shù)據(jù)操作。
2.使用vs提供的包管理工具Nuget進(jìn)行項(xiàng)目引用。

Nuget包管理工具

搜索SQLite安裝對(duì)應(yīng)的包,下載完成后就自動(dòng)在項(xiàng)目中引用了。
使用
創(chuàng)建數(shù)據(jù)庫(kù)
//創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)
SQLiteConnection.CreateFile("Database.sqlite");
操作數(shù)據(jù)庫(kù)
//創(chuàng)建連接字符串
SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;");
//這是數(shù)據(jù)庫(kù)登錄密碼
conn.SetPassword("1234");
//打開數(shù)據(jù)庫(kù)
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ù)庫(kù)

查表

設(shè)置主鍵,已經(jīng)自增。
主鍵自增類型必須是 INTEGER類型

其他
1.SQLite .NET驅(qū)動(dòng)設(shè)置數(shù)據(jù)庫(kù)讀取密碼
.net驅(qū)動(dòng)之中,提供了單獨(dú)設(shè)置密碼和登錄密碼
using (SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;"))
{
conn.Open();
//設(shè)置數(shù)據(jù)庫(kù)密碼
conn.ChangePassword("123456");
conn.Clone();
}
登錄帶密碼的數(shù)據(jù)庫(kù)
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();
}

密碼正確查詢成功

密碼錯(cuò)誤查詢異常
還有就是密碼設(shè)置錯(cuò)誤,打開數(shù)據(jù)庫(kù)后數(shù)據(jù)庫(kù)狀態(tài)依舊是打開狀態(tài),但是查詢后出現(xiàn)異常無(wú)法查詢。

使用 dotnet驅(qū)動(dòng)設(shè)置密碼之后,使用其他框架驅(qū)動(dòng)貌似就無(wú)法打開了。
FQA
1.大量數(shù)據(jù)頻繁Insert特別慢怎么辦?
解決辦法是使用事務(wù)來(lái)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;
}
總結(jié)
以上所述是小編給大家介紹的SQLite在C#中的安裝與操作技巧,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
在C#項(xiàng)目中調(diào)用C++編寫的動(dòng)態(tài)庫(kù)的三種方式
這篇文章給大家介紹了三種方式詳解如何在C#項(xiàng)目中調(diào)用C++編寫的動(dòng)態(tài)庫(kù),文中通過代碼示例給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-01-01
C#/VB.NET實(shí)現(xiàn)在Word文檔中添加頁(yè)眉和頁(yè)腳
頁(yè)眉位于文檔中每個(gè)頁(yè)面的頂部區(qū)域,常用于顯示文檔的附加信息;頁(yè)腳位于文檔中每個(gè)頁(yè)面的底部的區(qū)域,常用于顯示文檔的附加信息。今天這篇文章就將為大家展示如何以編程的方式在在?Word?文檔中添加頁(yè)眉和頁(yè)腳2023-03-03
簡(jiǎn)單的excel導(dǎo)入導(dǎo)出示例分享
這篇文章主要介紹了簡(jiǎn)單的excel導(dǎo)入導(dǎo)出示例分享,需要的朋友可以參考下2014-03-03
C#實(shí)現(xiàn)人臉識(shí)別超簡(jiǎn)單方法舉例
這篇文章主要給大家介紹了關(guān)于C#實(shí)現(xiàn)人臉識(shí)別的相關(guān)資料,文中講解了在C#中使用EmguCV庫(kù)進(jìn)行人臉識(shí)別的簡(jiǎn)單示例,包括安裝EmguCV庫(kù)、準(zhǔn)備訓(xùn)練數(shù)據(jù)、編寫代碼和運(yùn)行程序,需要的朋友可以參考下2024-11-11
c# Invoke和BeginInvoke 區(qū)別分析
這篇文章主要介紹了c# Invoke和BeginInvoke 區(qū)別分析,需要的朋友可以參考下2014-10-10
C#實(shí)現(xiàn)數(shù)字轉(zhuǎn)換
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)數(shù)字轉(zhuǎn)換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04

