• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C#教程 > C#封装的Sqlite访问类实例

C#封装的Sqlite访问类实例

作者:令狐不聪 字体:[增加 减小] 来源:互联网 时间:2017-05-28

令狐不聪 通过本文主要向大家介绍了c#sqlite,c#中使用sqlite,c#如何使用sqlite,c#连接sqlite数据库,c#操作sqlite等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了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, SQLSt



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C# SQlite操作方法小结
  • C#封装的Sqlite访问类实例
  • C#实现Excel导入sqlite的方法
  • C#中实现在32位、64位系统下自动切换不同的SQLite dll文件
  • C#/Java连接sqlite与使用技巧

相关文章

  • 2017-05-28C# 装箱和拆箱的知识回顾
  • 2017-05-28C#的WebBrowser操作frame实例解析
  • 2017-05-28浅谈C# 非模式窗体show()和模式窗体showdialog()的区别
  • 2017-05-28深入解析C#编程中泛型委托的使用
  • 2017-05-28C#编写的windows计算器的实例代码
  • 2017-05-28C#导出网站功能实例代码讲解
  • 2017-05-28基于DateTime.ParseExact方法的使用详解
  • 2017-05-28C#编程自学之流程控制语句
  • 2017-05-28C#生成XML的三种途径小结
  • 2017-05-28C#中实现Json序列化与反序列化的几种方式

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C#实现将选中复选框的信息返回给用户的方法
    • C# 拓展方法的简单实例
    • C#实现从多列的DataTable里取需要的几列
    • C#定时器实现自动执行的方法
    • C# IsDefined的问题
    • C#简单写入xml文件的方法
    • C#实现异步连接Sql Server数据库的方法
    • C++联合体转换成C#结构的实现方法
    • C#实现文件断点续传下载的方法
    • C#中Array与ArrayList用法及转换的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有