亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C# SQLite數據庫入門使用說明

發布時間:2020-10-03 16:56:18 來源:腳本之家 閱讀:762 作者:任前程 欄目:編程語言

前言

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

一、NuGet引入SQLite庫

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

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

C# SQLite數據庫入門使用說明

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

C# SQLite數據庫入門使用說明

二、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 設置的值
  //private readonly static string appStr = ConfigurationManager.AppSettings["TestKey"];

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

  //執行非查詢語句
  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();
   }
  }

  //執行非查詢語句-獨立連接
  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. 判斷數據文件是否存在

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


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

2. 判斷表是否存在

/// <summary>
/// 檢查數據表是否存在,不存在創建
/// </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)
   {
    //創建表
    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;
   ";
    //此語句返回結果為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?

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肇源县| 县级市| 莱州市| 毕节市| 卢湾区| 河源市| 昌吉市| 泰兴市| 岳西县| 庆元县| 清涧县| 京山县| 霍山县| 嘉定区| 涟水县| 沙坪坝区| 阿瓦提县| 个旧市| 开江县| 隆德县| 土默特右旗| 赫章县| 巴彦淖尔市| 浦江县| 淮南市| 建阳市| 凉城县| 北京市| 大城县| 博爱县| 万年县| 全州县| 米易县| 昌都县| 安远县| 东宁县| 莱芜市| 兴安县| 平原县| 商丘市| 交城县|