欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

C#SQLite數(shù)據(jù)庫入門使用說明

前言

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供曲周網(wǎng)站建設(shè)、曲周做網(wǎng)站、曲周網(wǎng)站設(shè)計、曲周網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、曲周企業(yè)網(wǎng)站模板建站服務,10余年曲周做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務。

我們在開發(fā)應用是經(jīng)常會需要用到一些數(shù)據(jù)的存儲,存儲的方式有多種,使用數(shù)據(jù)庫是一種比較受大家歡迎的方式。但是對于一些小型的應用,如一些移動APP,通常的數(shù)據(jù)庫過于龐大,而輕便的SQLite則能解決這一問題。不但操作方便,而且只需要要一個文件即可,在這里我們來說一說使用C#語言操作SQLite數(shù)據(jù)庫。

一、NuGet引入SQLite庫

在VS菜單:工具→NuGet包管理器→管理解決方案的NuGet程序包 打開NuGet解決方案窗口。

搜索 sqlite,選擇官方的庫安裝到指定的項目中。:

C# SQLite數(shù)據(jù)庫入門使用說明

提示:System.Data.SQLite 分為 x86 和 x64 版本,這里推薦使用NuGet自動安裝。使用 Any CPU 編譯的時候,會自動拷貝32位和64位 Interop DLL文件到子目錄中。程序運行的時候會根據(jù)電腦的運行環(huán)境自動選擇合適的dll。

C# SQLite數(shù)據(jù)庫入門使用說明

二、DBHelper類庫

using System.Collections.Generic;
using System.Data;
using System.Data.SQLite;
using System.Configuration;
using System.Data.SqlClient;
//using MySQL.Data.MySqlClient;

namespace ConsoleApp5
{
 public class DBHelper
 {
  private readonly static string connStr = ConfigurationManager.ConnectionStrings["Data Source=mesclient.sqlite;Version=3"].ConnectionString;

  //獲取 appsetting 設(shè)置的值
  //private readonly static string appStr = ConfigurationManager.AppSettings["TestKey"];

  //獲取 connection 對象
  public static IDbConnection CreateConnection()
  {
   IDbConnection conn = new SQLiteConnection(connStr);//MySqlConnection //SqlConnection
   conn.Open();
   return conn;
  }

  //執(zhí)行非查詢語句
  public static int ExecuteNonQuery(IDbConnection conn, string sql, Dictionary<string, object> parameters)
  {
   using (IDbCommand cmd = conn.CreateCommand())
   {
    cmd.CommandText = sql;
    foreach (KeyValuePair<string, object> keyValuePair in parameters)
    {
     IDbDataParameter parameter = cmd.CreateParameter();
     parameter.ParameterName = keyValuePair.Key;
     parameter.Value = keyValuePair.Value;
     cmd.Parameters.Add(parameter);
    }
    return cmd.ExecuteNonQuery();
   }
  }

  //執(zhí)行非查詢語句-獨立連接
  public static int ExecuteNonQuery(string sql, Dictionary<string, object> parameters)
  {
   using (IDbConnection conn = CreateConnection())
   {
    return ExecuteNonQuery(conn, sql, parameters);
   }
  }

  //查詢首行首列
  public static object ExecuteScalar(IDbConnection conn, string sql, Dictionary<string, object> parameters)
  {
   using (IDbCommand cmd = conn.CreateCommand())
   {
    cmd.CommandText = sql;
    foreach (KeyValuePair<string, object> keyValuePair in parameters)
    {
     IDbDataParameter parameter = cmd.CreateParameter();
     parameter.ParameterName = keyValuePair.Key;
     parameter.Value = keyValuePair.Value;
     cmd.Parameters.Add(parameter);
    }
    return cmd.ExecuteScalar();
   }
  }

  //查詢首行首列-獨立連接
  public static object ExecuteScalar(string sql, Dictionary<string, object> parameters)
  {
   using (IDbConnection conn = CreateConnection())
   {
    return ExecuteScalar(conn, sql, parameters);
   }
  }

  //查詢表
  public static DataTable ExecuteQuery(IDbConnection conn, string sql, Dictionary<string, object> parameters)
  {
   DataTable dt = new DataTable();
   using (IDbCommand cmd = conn.CreateCommand())
   {
    cmd.CommandText = sql;
    foreach (KeyValuePair<string, object> keyValuePair in parameters)
    {
     IDbDataParameter parameter = cmd.CreateParameter();
     parameter.ParameterName = keyValuePair.Key;
     parameter.Value = keyValuePair.Value;
     cmd.Parameters.Add(parameter);
    }
    using (IDataReader reader = cmd.ExecuteReader())
    {
     dt.Load(reader);
    }
   }

   return dt;
  }

  //查詢表--獨立連接
  public static DataTable ExecuteQuery(string sql, Dictionary<string, object> parameters)
  {
   using (IDbConnection conn = CreateConnection())
   {
    return ExecuteQuery(conn, sql, parameters);
   }
  }
 }
}

三、基本使用

1. 判斷數(shù)據(jù)文件是否存在

/// <summary>
/// 檢查數(shù)據(jù)庫是否存在不存在創(chuàng)建
/// </summary>
/// <returns></returns>
public static bool CheckDataBase()
{
 try
 {
  //判斷數(shù)據(jù)文件是否存在
  bool dbExist = File.Exists("mesclient.sqlite");
  if (!dbExist)
  {
   SQLiteConnection.CreateFile("mesclient.sqlite");
  }


  return true;
 }
 catch (Exception)
 {
  return false;
 }
}

2. 判斷表是否存在

/// <summary>
/// 檢查數(shù)據(jù)表是否存在,不存在創(chuàng)建
/// </summary>
/// <returns></returns>
public static bool CheckDataTable(string connStr)
{
 try
 {
  using (SQLiteConnection conn = new SQLiteConnection(connStr))
  using (SQLiteCommand cmd = conn.CreateCommand())
  {
   conn.Open();
   cmd.CommandText = "SELECT count(*) FROM sqlite_master WHERE type = 'table' AND name = 'serverinfo'";
   object ob = cmd.ExecuteScalar();
   long tableCount = Convert.ToInt64(ob);
   if (tableCount == 0)
   {
    //創(chuàng)建表
    cmd.CommandText = @"
   BEGIN;
    create table serverinfo 
    (Id INTEGER PRIMARY KEY AUTOINCREMENT,Name TEXT,
    Url text,DelayTime integer,UsageCounter INTEGER,
     Status integer,CreateTime DATETIME);
    CREATE UNIQUE INDEX idx_serverInfo ON serverinfo (Name);
   COMMIT;
   ";
    //此語句返回結(jié)果為0
    int rowCount = cmd.ExecuteNonQuery();
    return true;
   }
   else if (tableCount > 1)
   {
    return false;
   }
   else
   {
    return true;
   }
  }
 }
 catch (Exception ex)
 {
  return false;
 }
}

3. 查詢

string sql = "SELECT * FROM serverinfo WHERE Name =@ServerName AND Url = @Url and date(CreateTime)=date(@Date);";
Dictionary<string, object> parameters = new Dictionary<string, object>();
parameters.Add("ServerName",endpointElement.Name);
parameters.Add("Url", endpointElement.Address);
parameters.Add("Date", DateTime.Now.ToString("yyyy-MM-dd"));
DataTable dt=SqliteHelper.ExecuteQuery(connStr, sql, parameters);
if (dt.Rows.Count>0)
{
 UsageCounter = dt.Rows[0].Field<long>("UsageCounter");
 GetTime = dt.Rows[0].Field<DateTime>("CreateTime");
}

4. 新增/修改

//存在更新,不存在插入
string updateSql = "REPLACE INTO serverinfo(Name,Url,DelayTime,UsageCounter, Status,CreateTime) VALUES(@Name,@Url,@DelayTime,@UsageCounter,@Status, @CreateTime)";
Dictionary<string, object> ups = new Dictionary<string, object>();
ups.Add("Name", name);
ups.Add("Url", url);
ups.Add("DelayTime", delayTime);
ups.Add("UsageCounter", usageCounter);
ups.Add("Status", status);
ups.Add("CreateTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
int count= SqliteHelper.ExecuteNonQuery(connStr, updateSql, ups);
if (count>0)
{
 return true;
}
else
{
 return false;
}

5. 刪除

//刪除記錄
string updateSql =
 "DELETE FROM serverinfo where content=@Content and flag=@Flag;";
Dictionary<string, object> updateParameters = new Dictionary<string, object>();
updateParameters.Add("Content", Content);
updateParameters.Add("Flag", Flag);
int count = SqliteHelper.ExecuteNonQuery(connStr, updateSql, updateParameters);
if (count > 0)
{
 return true;
}
else
{
 return false;
}

四、參考文章

  • Create SQLite Database and table
  • Writing to a SQLite Database in C#
  • SQLite with VS2012 and .NET 4.5 — ANY CPU Build
  • how to check if a table exists in C#
  • SQLite auto increment issue
  • Inserting a date to SQLite
  • SQLite REPLACE Statement
  • sqlite select with condition on date
  • Using SQLite how do I index columns in a CREATE TABLE statement?

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對創(chuàng)新互聯(lián)的支持。

新聞標題:C#SQLite數(shù)據(jù)庫入門使用說明
網(wǎng)頁路徑:http://aaarwkj.com/article4/pdeiie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)、定制開發(fā)、網(wǎng)站維護網(wǎng)站導航、關(guān)鍵詞優(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)

營銷型網(wǎng)站建設(shè)
青青草原在线免费视频| 亚洲欧洲美洲中文天堂| 精品黄色大片不卡国产| 粉嫩护士国产在线观看| 精品一区中文字幕少妇人妻 | 男女午夜激情四射视频| 欧美亚洲国产日韩另类| 久久精品中文字幕人妻| 久久婷婷综合激情亚洲| 亚洲成色在线综合剧情网站| 国产又粗又猛又爽黄老大爷| 久久久久四虎国产精品| 97免费在线视频观看| 视频播放一区二区三区毛片| 国内一级片内射免费视频观看| 成人av久久一区二区三区| 中文乱码字幕亚洲精品| 日本师生三片在线观看| 激情五月婷婷我有我色| 日本午夜精品在线观看| 色久悠悠婷婷综合在线亚洲| 国产精品国产三级专区| 亚洲高清成人综合网站| 97久久成人国产精品免费| 99热国产这里只有精品| 综合久久99中文综合久久| 中文字幕一区精品日韩| 亚洲日本熟妇在线视频| 国产成人精品久久久亚洲| av在线免费观看美日韩| 日本91一区二区不卡| 色婷婷av一区二区三| 国产精品久久久毛片av| 亚洲视频一直看一直爽| 91一区二区亚洲嫩草| 一区二区三区毛片免费| 久久欧精品欧美日韩精品| 精品蜜臀国产av一区二区| 91精品大片免费在线观看| 欧美日韩一区二区三区色拉拉 | 视频一区欧美日韩精品|