欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQLite在C#中的安裝與操作技巧

 更新時間:2017年08月29日 10:04:17   作者:藍曈魅  
SQLite,是一款輕型的數據庫,用于本地的數據儲存。其優(yōu)點有很多,下面通過本文給大家介紹SQLite在C#中的安裝與操作技巧,感興趣的的朋友參考下吧

SQLite 介紹

SQLite,是一款輕型的數據庫,用于本地的數據儲存。

先說說優(yōu)點,它占用資源非常的低,在嵌入式設備中需要幾百K的內存就夠了;作為輕量級數據庫,他的處理速度也足夠快;支持的的容量級別為T級;獨立: 沒有額外依賴;開源;支持多種語言;

我的用途

在項目開發(fā)中,需要做一次數據數據同步。因為數據庫實時數據的同步,需要記錄更新時間,系統(tǒng)日志等等數據;當然,你也可以選擇寫ini和xml等等配置文件來解決,但是都如數據庫可讀性高不是。

安裝

1. 引用 .NET 驅動 http://system.data.sqlite.org/index.html/doc/trunk/www/index.wiki

這三個文件,在項目中,引用之后就可以進行創(chuàng)建數據庫查詢數據操作。

2.使用vs提供的包管理工具Nuget進行項目引用。

Nuget包管理工具

搜索SQLite安裝對應的包,下載完成后就自動在項目中引用了。

使用

創(chuàng)建數據庫

 //創(chuàng)建一個數據庫
 SQLiteConnection.CreateFile("Database.sqlite");

操作數據庫

//創(chuàng)建連接字符串
SQLiteConnection conn = new SQLiteConnection("Data Source=Database.sqlite;Version=3;");
//這是數據庫登錄密碼
conn.SetPassword("1234");
//打開數據庫
conn.Open();
string query = "create table table1 (id INTEGER, name VARCHAR)";
//創(chuàng)建命令
SQLiteCommand cmd = new SQLiteCommand(query, conn);
//執(zhí)行命令
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();
}

密碼正確查詢成功

密碼錯誤查詢異常

還有就是密碼設置錯誤,打開數據庫后數據庫狀態(tài)依舊是打開狀態(tài),但是查詢后出現異常無法查詢。

使用 dotnet驅動設置密碼之后,使用其他框架驅動貌似就無法打開了。

FQA

1.大量數據頻繁Insert特別慢怎么辦?

  解決辦法是使用事務來Insert數據.

  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#中的安裝與操作技巧,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • 使用C#實現數據結構堆的代碼

    使用C#實現數據結構堆的代碼

    這篇文章主要介紹了使用C#實現數據結構堆,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • C#使用OpenCV剪切圖像中的圓形和矩形的示例代碼

    C#使用OpenCV剪切圖像中的圓形和矩形的示例代碼

    這篇文章主要介紹了C#使用OpenCV剪切圖像中的圓形和矩形,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • C#.NET實現網頁自動登錄的方法

    C#.NET實現網頁自動登錄的方法

    這篇文章主要介紹了C#.NET實現網頁自動登錄的方法,以實例形式分析了C#實現點擊自動登錄的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09
  • C#很簡單而又很經典的一句代碼實例

    C#很簡單而又很經典的一句代碼實例

    這篇文章主要給大家分享介紹了關于C#很簡單而又很經典的一句代碼,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C#具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • C#中的Explicit和Implicit詳情

    C#中的Explicit和Implicit詳情

    Implicit提高了代碼的可讀性,但程序員需要自己保證轉換不引發(fā)異常且不丟失信息、Explicit可阻止編譯器靜默調用可能產生意外后果的轉換操作。前者更易于使用,后者能向閱讀代碼的每個人清楚地指示您要轉換類型,下面就和小編來一起學習吧
    2021-09-09
  • C#實現HSL顏色值轉換為RGB的方法

    C#實現HSL顏色值轉換為RGB的方法

    這篇文章主要介紹了C#實現HSL顏色值轉換為RGB的方法,涉及C#數值判定與轉換的相關技巧,需要的朋友可以參考下
    2015-06-06
  • C#把文件上傳到服務器中的指定地址

    C#把文件上傳到服務器中的指定地址

    這篇文章介紹了C#實現文件上傳到服務器指定地址的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • C#開啟線程的四種方式示例詳解

    C#開啟線程的四種方式示例詳解

    今天小編就為大家分享一篇關于C#開啟線程的四種方式示例詳解,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • c# 動態(tài)構建LINQ查詢表達式

    c# 動態(tài)構建LINQ查詢表達式

    這篇文章主要介紹了c# 如何動態(tài)構建LINQ查詢表達式,幫助大家更好的理解和學習c#,感興趣的朋友可以了解下
    2020-11-11
  • Unity shader實現高斯模糊效果

    Unity shader實現高斯模糊效果

    這篇文章主要為大家詳細介紹了Unity shader實現高斯模糊效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02

最新評論