真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

前言

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

我們在開發(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 設置的值
  //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 parameters)
  {
   using (IDbCommand cmd = conn.CreateCommand())
   {
    cmd.CommandText = sql;
    foreach (KeyValuePair 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 parameters)
  {
   using (IDbConnection conn = CreateConnection())
   {
    return ExecuteNonQuery(conn, sql, parameters);
   }
  }

  //查詢首行首列
  public static object ExecuteScalar(IDbConnection conn, string sql, Dictionary parameters)
  {
   using (IDbCommand cmd = conn.CreateCommand())
   {
    cmd.CommandText = sql;
    foreach (KeyValuePair 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 parameters)
  {
   using (IDbConnection conn = CreateConnection())
   {
    return ExecuteScalar(conn, sql, parameters);
   }
  }

  //查詢表
  public static DataTable ExecuteQuery(IDbConnection conn, string sql, Dictionary parameters)
  {
   DataTable dt = new DataTable();
   using (IDbCommand cmd = conn.CreateCommand())
   {
    cmd.CommandText = sql;
    foreach (KeyValuePair 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 parameters)
  {
   using (IDbConnection conn = CreateConnection())
   {
    return ExecuteQuery(conn, sql, parameters);
   }
  }
 }
}

三、基本使用

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

/// 
/// 檢查數(shù)據(jù)庫是否存在不存在創(chuàng)建
/// 
/// 
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. 判斷表是否存在

/// 
/// 檢查數(shù)據(jù)表是否存在,不存在創(chuàng)建
/// 
/// 
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 parameters = new Dictionary();
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("UsageCounter");
 GetTime = dt.Rows[0].Field("CreateTime");
}

4. 新增/修改

//存在更新,不存在插入
string updateSql = "REPLACE INTO serverinfo(Name,Url,DelayTime,UsageCounter, Status,CreateTime) VALUES(@Name,@Url,@DelayTime,@UsageCounter,@Status, @CreateTime)";
Dictionary ups = new Dictionary();
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 updateParameters = new Dictionary();
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ù)庫入門使用說明
文章來源:http://weahome.cn/article/pdeiie.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部