欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C#教程

當(dāng)前位置:主頁 > 軟件編程 > C#教程 >

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

來源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C#教程|點(diǎn)擊: 次

SQLite 介紹

SQLite,是一款輕型的數(shù)據(jù)庫,用于本地的數(shù)據(jù)儲存。

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

我的用途

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

安裝

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ù)庫查詢數(shù)據(jù)操作。

2.使用vs提供的包管理工具Nuget進(jìn)行項(xiàng)目引用。

Nuget包管理工具

搜索SQLite安裝對應(yīng)的包,下載完成后就自動(dòng)在項(xiàng)目中引用了。

使用

創(chuàng)建數(shù)據(jù)庫

 //創(chuàng)建一個(gè)數(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ū)動(dòng)設(shè)置數(shù)據(jù)庫讀取密碼

.net驅(qū)動(dòng)之中,提供了單獨(dú)設(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();
}

密碼正確查詢成功

密碼錯(cuò)誤查詢異常

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

使用 dotnet驅(qū)動(dòng)設(shè)置密碼之后,使用其他框架驅(qū)動(dòng)貌似就無法打開了。

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;
}

總結(jié)

以上所述是小編給大家介紹的SQLite在C#中的安裝與操作技巧,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對我們網(wǎng)站的支持!

上一篇:詳解C# partial 關(guān)鍵字的使用

欄    目:C#教程

下一篇:C#匿名委托與Lambda表達(dá)式詳解

本文標(biāo)題:SQLite在C#中的安裝與操作技巧

本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5528.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有