bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

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

前言

創新互聯專業為企業提供曲周網站建設、曲周做網站、曲周網站設計、曲周網站制作等企業網站建設、網頁設計與制作、曲周企業網站模板建站服務,10余年曲周做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。

我們在開發應用是經常會需要用到一些數據的存儲,存儲的方式有多種,使用數據庫是一種比較受大家歡迎的方式。但是對于一些小型的應用,如一些移動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?

總結

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

新聞標題:C#SQLite數據庫入門使用說明
網頁路徑:http://vcdvsql.cn/article4/pdeiie.html

成都網站建設公司_創新互聯,為您提供移動網站建設定制開發網站維護網站導航關鍵詞優化微信公眾號

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

營銷型網站建設