C#封装的Sqlite访问类实例

本文实例讲述了C#封装的Sqlite访问类。分享给大家供大家参考。具体分析如下:

C#封装的Sqlite访问类,要访问Sqlite这下简单了,直接调用此类中的方法即可

using System;
using System.Collections;
using System.Collections.Specialized;
using System.Data;
using System.Configuration;
using System.Data.SQLite;
namespace DAL
{
 internal abstract class DbHelperSQLite
 {
  public static string connectionString = "Data Source=" + AppDomain.CurrentDomain.BaseDirectory + @"dataleaf.db;Version=3;";
  public DbHelperSQLite()
  {
  }
  #region 公用方法
  public static int GetMaxID(string FieldName, string TableName)
  {
   string strsql = "select max(" + FieldName + ")+1 from " + TableName;
   object obj = GetSingle(strsql);
   if (obj == null)
   {
    return 1;
   }
   else
   {
    return int.Parse(obj.ToString());
   }
  }
  public static bool Exists(string strSql)
  {
   object obj = GetSingle(strSql);
   int cmdresult;
   if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))
   {
    cmdresult = 0;
   }
   else
   {
    cmdresult = int.Parse(obj.ToString());
   }
   if (cmdresult == 0)
   {
    return false;
   }
   else
   {
    return true;
   }
  }
  public static bool Exists(string strSql, params SQLiteParameter[] cmdParms)
  {
   object obj = GetSingle(strSql, cmdParms);
   int cmdresult;
   if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))
   {
    cmdresult = 0;
   }
   else
   {
    cmdresult = int.Parse(obj.ToString());
   }
   if (cmdresult == 0)
   {
    return false;
   }
   else
   {
    return true;
   }
  }
  #endregion
  #region 执行简单SQL语句
  /// <summary>
  /// 执行SQL语句,返回影响的记录数
  /// </summary>
  /// <param name="SQLString">SQL语句</param>
  /// <returns>影响的记录数</returns>
  public static int ExecuteSql(string SQLString)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    using (SQLiteCommand cmd = new SQLiteCommand(SQLString, connection))
    {
     try
     {
      connection.Open();
      int rows = cmd.ExecuteNonQuery();
      return rows;
     }
     catch (System.Data.SQLite.SQLiteException E)
     {
      connection.Close();
      throw new Exception(E.Message);
     }
    }
   }
  }
  /// <summary>
  /// 执行多条SQL语句,实现数据库事务。
  /// </summary>
  /// <param name="SQLStringList">多条SQL语句</param>
  public static void ExecuteSqlTran(ArrayList SQLStringList)
  {
   using (SQLiteConnection conn = new SQLiteConnection(connectionString))
   {
    conn.Open();
    SQLiteCommand cmd = new SQLiteCommand();
    cmd.Connection = conn;
    SQLiteTransaction tx = conn.BeginTransaction();
    cmd.Transaction = tx;
    try
    {
     for (int n = 0; n < SQLStringList.Count; n++)
     {
      string strsql = SQLStringList[n].ToString();
      if (strsql.Trim().Length > 1)
      {
       cmd.CommandText = strsql;
       cmd.ExecuteNonQuery();
      }
     }
     tx.Commit();
    }
    catch (System.Data.SQLite.SQLiteException E)
    {
     tx.Rollback();
     throw new Exception(E.Message);
    }
   }
  }
  /// <summary>
  /// 执行带一个存储过程参数的的SQL语句。
  /// </summary>
  /// <param name="SQLString">SQL语句</param>
  /// <param name="content">参数内容,比如一个字段是格式复杂的文章,有特殊符号,可以通过这个方式添加</param>
  /// <returns>影响的记录数</returns>
  public static int ExecuteSql(string SQLString, string content)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    SQLiteCommand cmd = new SQLiteCommand(SQLString, connection);
    SQLiteParameter myParameter = new SQLiteParameter("@content", DbType.String);
    myParameter.Value = content;
    cmd.Parameters.Add(myParameter);
    try
    {
     connection.Open();
     int rows = cmd.ExecuteNonQuery();
     return rows;
    }
    catch (System.Data.SQLite.SQLiteException E)
    {
     throw new Exception(E.Message);
    }
    finally
    {
     cmd.Dispose();
     connection.Close();
    }
   }
  }
  /// <summary>
  /// 向数据库里插入图像格式的字段(和上面情况类似的另一种实例)
  /// </summary>
  /// <param name="strSQL">SQL语句</param>
  /// <param name="fs">图像字节,数据库的字段类型为image的情况</param>
  /// <returns>影响的记录数</returns>
  public static int ExecuteSqlInsertImg(string strSQL, byte[] fs)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    SQLiteCommand cmd = new SQLiteCommand(strSQL, connection);
    SQLiteParameter myParameter = new SQLiteParameter("@fs", DbType.Binary);
    myParameter.Value = fs;
    cmd.Parameters.Add(myParameter);
    try
    {
     connection.Open();
     int rows = cmd.ExecuteNonQuery();
     return rows;
    }
    catch (System.Data.SQLite.SQLiteException E)
    {
     throw new Exception(E.Message);
    }
    finally
    {
     cmd.Dispose();
     connection.Close();
    }
   }
  }
  /// <summary>
  /// 执行一条计算查询结果语句,返回查询结果(object)。
  /// </summary>
  /// <param name="SQLString">计算查询结果语句</param>
  /// <returns>查询结果(object)</returns>
  public static object GetSingle(string SQLString)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    using (SQLiteCommand cmd = new SQLiteCommand(SQLString, connection))
    {
     try
     {
      connection.Open();
      object obj = cmd.ExecuteScalar();
      if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))
      {
       return null;
      }
      else
      {
       return obj;
      }
     }
     catch (System.Data.SQLite.SQLiteException e)
     {
      connection.Close();
      throw new Exception(e.Message);
     }
    }
   }
  }
  /// <summary>
  /// 执行查询语句,返回SQLiteDataReader
  /// </summary>
  /// <param name="strSQL">查询语句</param>
  /// <returns>SQLiteDataReader</returns>
  public static SQLiteDataReader ExecuteReader(string strSQL)
  {
   SQLiteConnection connection = new SQLiteConnection(connectionString);
   SQLiteCommand cmd = new SQLiteCommand(strSQL, connection);
   try
   {
    connection.Open();
    SQLiteDataReader myReader = cmd.ExecuteReader();
    return myReader;
   }
   catch (System.Data.SQLite.SQLiteException e)
   {
    throw new Exception(e.Message);
   }
  }
  /// <summary>
  /// 执行查询语句,返回DataSet
  /// </summary>
  /// <param name="SQLString">查询语句</param>
  /// <returns>DataSet</returns>
  public static DataSet Query(string SQLString)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    DataSet ds = new DataSet();
    try
    {
     connection.Open();
     SQLiteDataAdapter command = new SQLiteDataAdapter(SQLString, connection);
     command.Fill(ds, "ds");
    }
    catch (System.Data.SQLite.SQLiteException ex)
    {
     throw new Exception(ex.Message);
    }
    return ds;
   }
  }
  #endregion
  #region 执行带参数的SQL语句
  /// <summary>
  /// 执行SQL语句,返回影响的记录数
  /// </summary>
  /// <param name="SQLString">SQL语句</param>
  /// <returns>影响的记录数</returns>
  public static int ExecuteSql(string SQLString, params SQLiteParameter[] cmdParms)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    using (SQLiteCommand cmd = new SQLiteCommand())
    {
     try
     {
      PrepareCommand(cmd, connection, null, SQLString, cmdParms);
      int rows = cmd.ExecuteNonQuery();
      cmd.Parameters.Clear();
      return rows;
     }
     catch (System.Data.SQLite.SQLiteException E)
     {
      throw new Exception(E.Message);
     }
    }
   }
  }
  /// <summary>
  /// 执行多条SQL语句,实现数据库事务。
  /// </summary>
  /// <param name="SQLStringList">SQL语句的哈希表(key为sql语句,value是该语句的SQLiteParameter[])</param>
  public static void ExecuteSqlTran(Hashtable SQLStringList)
  {
   using (SQLiteConnection conn = new SQLiteConnection(connectionString))
   {
    conn.Open();
    using (SQLiteTransaction trans = conn.BeginTransaction())
    {
     SQLiteCommand cmd = new SQLiteCommand();
     try
     {
      //循环
      foreach (DictionaryEntry myDE in SQLStringList)
      {
       string cmdText = myDE.Key.ToString();
       SQLiteParameter[] cmdParms = (SQLiteParameter[])myDE.Value;
       PrepareCommand(cmd, conn, trans, cmdText, cmdParms);
       int val = cmd.ExecuteNonQuery();
       cmd.Parameters.Clear();
       trans.Commit();
      }
     }
     catch
     {
      trans.Rollback();
      throw;
     }
    }
   }
  }
  /// <summary>
  /// 执行一条计算查询结果语句,返回查询结果(object)。
  /// </summary>
  /// <param name="SQLString">计算查询结果语句</param>
  /// <returns>查询结果(object)</returns>
  public static object GetSingle(string SQLString, params SQLiteParameter[] cmdParms)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    using (SQLiteCommand cmd = new SQLiteCommand())
    {
     try
     {
      PrepareCommand(cmd, connection, null, SQLString, cmdParms);
      object obj = cmd.ExecuteScalar();
      cmd.Parameters.Clear();
      if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))
      {
       return null;
      }
      else
      {
       return obj;
      }
     }
     catch (System.Data.SQLite.SQLiteException e)
     {
      throw new Exception(e.Message);
     }
    }
   }
  }
  /// <summary>
  /// 执行查询语句,返回SQLiteDataReader
  /// </summary>
  /// <param name="strSQL">查询语句</param>
  /// <returns>SQLiteDataReader</returns>
  public static SQLiteDataReader ExecuteReader(string SQLString, params SQLiteParameter[] cmdParms)
  {
   SQLiteConnection connection = new SQLiteConnection(connectionString);
   SQLiteCommand cmd = new SQLiteCommand();
   try
   {
    PrepareCommand(cmd, connection, null, SQLString, cmdParms);
    SQLiteDataReader myReader = cmd.ExecuteReader();
    cmd.Parameters.Clear();
    return myReader;
   }
   catch (System.Data.SQLite.SQLiteException e)
   {
    throw new Exception(e.Message);
   }
  }
  /// <summary>
  /// 执行查询语句,返回DataSet
  /// </summary>
  /// <param name="SQLString">查询语句</param>
  /// <returns>DataSet</returns>
  public static DataSet Query(string SQLString, params SQLiteParameter[] cmdParms)
  {
   using (SQLiteConnection connection = new SQLiteConnection(connectionString))
   {
    SQLiteCommand cmd = new SQLiteCommand();
    PrepareCommand(cmd, connection, null, SQLString, cmdParms);
    using (SQLiteDataAdapter da = new SQLiteDataAdapter(cmd))
    {
     DataSet ds = new DataSet();
     try
     {
      da.Fill(ds, "ds");
      cmd.Parameters.Clear();
     }
     catch (System.Data.SQLite.SQLiteException ex)
     {
      throw new Exception(ex.Message);
     }
     return ds;
    }
   }
  }
  private static void PrepareCommand(SQLiteCommand cmd, SQLiteConnection conn, SQLiteTransaction trans, string cmdText, SQLiteParameter[] cmdParms)
  {
   if (conn.State != ConnectionState.Open)
    conn.Open();
   cmd.Connection = conn;
   cmd.CommandText = cmdText;
   if (trans != null)
    cmd.Transaction = trans;
   cmd.CommandType = CommandType.Text;//cmdType;
   if (cmdParms != null)
   {
    foreach (SQLiteParameter parm in cmdParms)
     cmd.Parameters.Add(parm);
   }
  }
  #endregion
 }
}

希望本文所述对大家的C#程序设计有所帮助。

(0)

相关推荐

  • C# SQLite事务操作方法分析

    本文实例讲述了C# SQLite事务操作方法.分享给大家供大家参考,具体如下: 在 C#中执行Sqlite数据库事务有两种方式:SQL代码和C#代码 1. SQL代码: BEGIN- COMMIT /ROLLBACK 2. C#代码: using (SQLiteConnection conn = SqliteHelper.GetSQLiteConnection()) { DbTransaction trans = conn.BeginTransaction(); try { //Sql语句 tr

  • C#事务处理(Execute Transaction)实例解析

    本文所述为C#事务处理(Execute Transaction)的一个实例,包含了创建SqlTransaction 对象并用SqlConnection对象的BeginTransaction()方法开始事务,创建保存SQL语句,将SqlCommand对象的CommandText属性设置为第一个INSERT语句,第一个INSERT语句在Customers表中增加一行,提交事务,使INSERT语句增加的两行在数据库中保存起来. 具体的实例代码如下: using System; using System

  • c#几种数据库的大数据批量插入(SqlServer、Oracle、SQLite和MySql)

    在之前只知道SqlServer支持数据批量插入,殊不知道Oracle.SQLite和MySql也是支持的,不过Oracle需要使用Orace.DataAccess驱动,今天就贴出几种数据库的批量插入解决方法. 首先说一下,IProvider里有一个用于实现批量插入的插件服务接口IBatcherProvider,此接口在前一篇文章中已经提到过了. /// <summary> /// 提供数据批量处理的方法. /// </summary> public interface IBatch

  • C#简单访问SQLite数据库的方法(安装,连接,查询等)

    本文实例讲述了C#简单访问SQLite数据库的方法.分享给大家供大家参考,具体如下: 下载最新版SQLite(http://www.sqlite.org/download.html),其他版本也可以,这里使用的版本是sqlite-3_6_6_1 a.解压后copy c:\sqlite-3_6_6_1 b.进入cmd模式,进入sqlite-3_6_6_1目录,执行sqlite3 mytest.db c. create table test (seq int,desc varchar(8)); in

  • C#基于SQLiteHelper类似SqlHelper类实现存取Sqlite数据库的方法

    本文实例讲述了C#基于SQLiteHelper类似SqlHelper类实现存取Sqlite数据库的方法.分享给大家供大家参考.具体如下: 这个类不是我实现的,英文原文地址为http://www.eggheadcafe.com/articles/20050315.asp,这里修改了原文中分析sql语句参数的方法,将方法名修改为AttachParameters,将其修饰符修改为private,并直接传递command到这个方法,直接绑定参数到comand.修改后的代码如下 using System;

  • C#操作SQLite数据库帮助类详解

    本文实例讲述了C#操作SQLite数据库帮助类.分享给大家供大家参考,具体如下: 最近有WPF做客户端,需要离线操作存储数据,在项目中考虑使用Sqlite嵌入式数据库,在网上找了不少资料,最终整理出一个公共的帮助类. Sqlite是一个非常小巧的数据库,基本上具备关系型数据库操作的大多数功能,Sql语法也大同小异.下面是我整理的帮助类代码: 1.获取 SQLiteConnection 对象,传入数据库有地址即可. /// <summary> /// 获得连接对象 /// </summar

  • C#调用SQLite的方法实例分析

    本文实例讲述了C#调用SQLite的方法.分享给大家供大家参考.具体分析如下: 一.SQLite简介: 当我们用到海量数据时一般会用Oracle,SQL Server,DB2,Sybase,MySQL等数据库来保存和管理数据.如果只是程序中需要保存少量数据的话直接整到注册表里,或者保存到一个XML文件中.那如果数据量刚好不多不少,用Oracle这样的数据库有点小题大作,没有必要.有个XML保存的话存取速度又比较慢.咋整呢?这时用SQLite这个小型的嵌入式数据库就是非常理想的选择.它用起来也很简

  • C#操作SQLite方法实例详解

    本文实例讲述了C#操作SQLite方法.分享给大家供大家参考.具体分析如下: 地址: System.Data.Sqlite入手... 首先import/using: 复制代码 代码如下: using System.Data.SQLite; Connection和Command: private SQLiteConnection conn; private SQLiteCommand cmd; 连接db: conn = new SQLiteConnection("Data Source=c:\\t

  • C# SQlite操作方法小结

    本文实例分析了C# SQlite操作方法.分享给大家供大家参考,具体如下: 最近项目需求用C#保存一些数据,如此先总结一下.需要下载Sqlite 库 SourceForge 链接网址http://sourceforge.net/projects/sqlite-dotnet2/或到官方网http://www.sqlite.org/download.html下载都可以,下载之后安装.在C#项目中添加引用 引入安装目录bin中的System.Data.SQLite.dll.添加命名空间using Sy

  • C#操作SQLite数据库之读写数据库的方法

    本文实例讲述了C#操作SQLite数据库之读写数据库的方法.分享给大家供大家参考,具体如下: 这里演示读写数据库并在窗体(Form)中显示其数据,其方式为: 读: Database(SQLite) -> DataAdapter -> DataSet -> DataGridView 写: Database(SQLite) <- DataAdapter <- DataSet <- DataGridView 1.假设现有数据库表student,其字段如下: ID(自增字段,主

  • C#解决SQlite并发异常问题的方法(使用读写锁)

    本文实例讲述了C#解决SQlite并发异常问题的方法.分享给大家供大家参考,具体如下: 使用C#访问sqlite时,常会遇到多线程并发导致SQLITE数据库损坏的问题. SQLite是文件级别的数据库,其锁也是文件级别的:多个线程可以同时读,但是同时只能有一个线程写.Android提供了SqliteOpenHelper类,加入Java的锁机制以便调用.但在C#中未提供类似功能. 作者利用读写锁(ReaderWriterLock),达到了多线程安全访问的目标. using System; usin

  • C#操作SQLite数据库方法小结(创建,连接,插入,查询,删除等)

    本文实例讲述了C#操作SQLite数据库方法.分享给大家供大家参考,具体如下: SQLite介绍 SQLite is a software library that implements a self-contained, serverless, zero-configuration, transactional SQL database engine. SQLite是一个开源.免费的小型RDBMS(关系型数据库),能独立运行.无服务器.零配置.支持事物,用C实现,内存占用较小,支持绝大数的SQ

随机推荐