SQLite在C#中的安裝與操作技巧
SQLite 介紹
SQLite,是一款輕型的數(shù)據(jù)庫,用于本地的數(shù)據(jù)儲存。
先說說優(yōu)點,它占用資源非常的低,在嵌入式設備中需要幾百K的內存就夠了;作為輕量級數(shù)據(jù)庫,他的處理速度也足夠快;支持的的容量級別為T級;獨立: 沒有額外依賴;開源;支持多種語言;
我的用途
在項目開發(fā)中,需要做一次數(shù)據(jù)數(shù)據(jù)同步。因為數(shù)據(jù)庫實時數(shù)據(jù)的同步,需要記錄更新時間,系統(tǒng)日志等等數(shù)據(jù);當然,你也可以選擇寫ini和xml等等配置文件來解決,但是都如數(shù)據(jù)庫可讀性高不是。
安裝
1. 引用 .NET 驅動 http://system.data.sqlite.org/index.html/doc/trunk/www/index.wiki
這三個文件,在項目中,引用之后就可以進行創(chuàng)建數(shù)據(jù)庫查詢數(shù)據(jù)操作。
2.使用vs提供的包管理工具Nuget進行項目引用。
Nuget包管理工具
搜索SQLite安裝對應的包,下載完成后就自動在項目中引用了。
使用
創(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ù)庫
查表
設置主鍵,已經自增。
主鍵自增類型必須是 INTEGER類型
其他
1.SQLite .NET驅動設置數(shù)據(jù)庫讀取密碼
.net驅動之中,提供了單獨設置密碼和登錄密碼
using (SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;"))
{
  conn.Open();
  //設置數(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ù)據(jù)庫后數(shù)據(jù)庫狀態(tài)依舊是打開狀態(tài),但是查詢后出現(xiàn)異常無法查詢。
使用 dotnet驅動設置密碼之后,使用其他框架驅動貌似就無法打開了。
FQA
1.大量數(shù)據(jù)頻繁Insert特別慢怎么辦?
解決辦法是使用事務來Insert數(shù)據(jù).
SQLite給出的解釋是:正常執(zhí)行Insert,每一次執(zhí)行都占用一次IO,而使用事務執(zhí)行,直到Insert結束只占用一次IO;
執(zhí)行事務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#中的安裝與操作技巧,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對我們網站的支持!
您可能感興趣的文章
- 01-10C#實現(xiàn)將窗體固定在顯示器的左上角且不能移動的方法
 - 01-10C#實現(xiàn)在Form里面內嵌dos窗體的方法
 - 01-10C#中查找Dictionary中的重復值的方法
 - 01-10C#實現(xiàn)在啟動目錄創(chuàng)建快捷方式的方法
 - 01-10C#將圖片存放到SQL SERVER數(shù)據(jù)庫中的方法
 - 01-10關于nancy中的身份驗證
 - 01-10C#中的事務用法實例分析
 - 01-10C#編程自學之類和對象
 - 01-10C#創(chuàng)建不規(guī)則窗體的4種方式詳解
 - 01-10C#實現(xiàn)讀取DataSet數(shù)據(jù)并顯示在ListView控件中的方法
 


閱讀排行
本欄相關
- 01-10C#通過反射獲取當前工程中所有窗體并
 - 01-10關于ASP網頁無法打開的解決方案
 - 01-10WinForm限制窗體不能移到屏幕外的方法
 - 01-10WinForm繪制圓角的方法
 - 01-10C#實現(xiàn)txt定位指定行完整實例
 - 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
 - 01-10C#停止線程的方法
 - 01-10C#實現(xiàn)清空回收站的方法
 - 01-10C#通過重寫Panel改變邊框顏色與寬度的
 - 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已
 
隨機閱讀
- 04-02jquery與jsp,用jquery
 - 08-05DEDE織夢data目錄下的sessions文件夾有什
 - 01-10C#中split用法實例總結
 - 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
 - 01-10delphi制作wav文件的方法
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 01-10使用C語言求解撲克牌的順子及n個骰子
 - 01-10SublimeText編譯C開發(fā)環(huán)境設置
 - 01-11ajax實現(xiàn)頁面的局部加載
 - 08-05織夢dedecms什么時候用欄目交叉功能?
 


