• 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方法。分享给大家供大家参考。具体分析如下:

地址:

System.Data.Sqlite入手。。。

首先import/using: 

Connection和Command:

private SQLiteConnection conn; 
private SQLiteCommand cmd; 

</div>

连接db:

conn = new SQLiteConnection("Data Source=c:\\test.db"); 
 conn.Open(); 
</div>

INSERT/UPDATE:

cmd = conn.CreateCommand(); 
cmd.CommandText = "INSERT INTO user(email,name) VALUES ('email','name')"; 
cmd.ExecuteNonQuery(); 
 
cmd.CommandText = "UPDATE userSET name = 'Codelicious' WHERE ID = 1"; 
cmd.ExecuteNonQuery(); 
</div>

SELECT:

cmd.CommandText = "SELECT ID, name FROM user"; 
SQLiteDataReader reader = cmd.ExecuteReader(); 
if (reader.HasRows) 
{ 
  while (reader.Read()) 
  { 
   Console.WriteLine("ID: " + reader.GetInt16(0)); 
   Console.WriteLine("name: " + reader.GetString(1)); 
  } 
}
</div>

模板程序:

using System; 
using System.Data; 
using System.Data.Common; 
using System.Data.SQLite; 
namespace SQLiteQueryBrowser 
{ 
   /// <summary> 
   /// 说明:这是一个针对System.Data.SQLite的数据库常规操作封装的通用类。 
   /// </summary> 
   public class SQLiteDBHelper 
   { 
     private string connectionString = string.Empty; 
     /// <summary> 
     /// 构造函数 
     /// </summary> 
     /// <param name="dbPath">SQLite数据库文件路径</param> 
     public SQLiteDBHelper(string dbPath) 
     { 
       this.connectionString = "Data Source=" + dbPath; 
     } 
     /// <summary> 
     /// 创建SQLite数据库文件 
     /// </summary> 
     /// <param name="dbPath">要创建的SQLite数据库文件路径</param> 
     public static void CreateDB(string dbPath) 
     { 
       using (SQLiteConnection connection = new SQLiteConnection("Data Source=" + dbPath)) 
       { 
         connection.Open(); 
         using (SQLiteCommand command = new SQLiteCommand(connection)) 
         { 
           command.CommandText = "CREATE TABLE Demo(id integer NOT NULL PRIMARY KEY AUTOINCREMENT UNIQUE)"; 
           command.ExecuteNonQuery(); 
           command.CommandText = "DROP TABLE Demo"; 
           command.ExecuteNonQuery(); 
         } 
       } 
     } 
     /// <summary> 
     /// 对SQLite数据库执行增删改操作,返回受影响的行数。 
     /// </summary> 
     /// <param name="sql">要执行的增删改的SQL语句</param> 
     /// <param name="parameters">执行增删改语句所需要的参数,参数必须以它们在SQL语句中的顺序为准</param> 
     /// <returns></returns> 
     public int ExecuteNonQuery(string sql, SQLiteParameter[] parameters) 
     { 
       int affectedRows = 0; 
       using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 
       { 
         connection.Open(); 
         using (DbTransaction transaction = connection.BeginTransaction()) 
         { 
           using (SQLiteCommand command = new SQLiteCommand(connection)) 
           { 
             command.CommandText = sql; 
             if (parameters != null) 
             { 
               command.Parameters.AddRange(parameters); 
             } 
             affectedRows = command.ExecuteNonQuery(); 
           } 
           transaction.Commit(); 
         } 
       } 
       return affectedRows; 
     } 
     /// <summary> 
     /// 执行一个查询语句,返回一个关联的SQLiteDataReader实例 
     /// </summary> 
     /// <param name="sql">要执行的查询语句</param> 
     /// <param name="parameters">执行SQL查询语句所需要的参数,参数必须以它们在SQL语句中的顺序为准</param> 
     /// <returns></returns> 
     public SQLiteDataReader ExecuteReader(string sql, SQLiteParameter[] parameters) 
     { 
       SQLiteConnection connection = new SQLiteConnection(connectionString); 
       SQLiteCommand command = new SQLiteCommand(sql, connection); 
       if (parameters != null) 
       { 
         command.Parameters.AddRange(parameters); 
       } 
       connection.Open(); 
       return command.ExecuteReader(CommandBehavior.CloseConnection); 
     } 
     /// <summary> 
     /// 执行一个查询语句,返回一个包含查询结果的DataTable 
     /// </summary> 
     /// <param name="sql">要执行的查询语句</param> 
     /// <param name="parameters">执行SQL查询语句所需要的参数,参数必须以它们在SQL语句中的顺序为准</param> 
     /// <returns></returns> 
     public DataTable ExecuteDataTable(string sql, SQLiteParameter[] parameters) 
     { 
       using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 
       { 
         using (SQLiteCommand command = new SQLiteCommand(sql, connection)) 
         { 
           if (parameters != null) 
           { 
             command.Parameters.AddRange(parameters); 
           } 
           SQLiteDataAdapter adapter = new SQLiteDataAdapter(command); 
           DataTable data = new DataTable(); 
           adapter.Fill(data); 
           return data; 
         } 
       } 
     } 
     /// <summary> 
     /// 执行一个查询语句,返回查询结果的第一行第一列 
     /// </summary> 
     /// <param name="sql">要执行的查询语句</param> 
     /// <param name="parameters">执行SQL查询语句所需要的参数,参数必须以它们在SQL语句中的顺序为准</param> 
     /// <returns></returns> 
     public Object ExecuteScalar(string sql, SQLiteParameter[] parameters) 
     { 
       using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 
       { 
         using (SQLiteCommand command = new SQLiteCommand(sql, connection)) 
         { 
           if (parameters != null) 
           { 
             command.Parameters.AddRange(parameters); 
           } 
           SQLiteDataAdapter adapter = new SQLiteDataAdapter(command); 
           DataTable data = new DataTable(); 
           adapter.Fill(data); 
           return data; 
         } 
       } 
     } 
     /// <summary> 
     /// 查询数据库中的所有数据类型信息 
     /// </summary> 
     /// <returns></returns> 
     public DataTable GetSchema() 
     { 
       using (SQLiteConnection connection = new SQLiteConnection(connectionString)) 
       { 
         connection.Open(); 
         DataTable data=connection.GetSchema("TABLES"); 
         connection.Close(); 
         //foreach (DataColumn column in data.Columns) 
         //{ 
         //  Console.WriteLine(column.ColumnName); 
         //} 
         return data; 
       } 
     } 
   } 
}
</div>

完整的程序例子:

using System; 
using System.Collections.Generic; 
using System.Text; 
using System.Data; 
using System.Data.Common; 
using System.Data.SQLite; 
using SQLiteQueryBrowser; 
namespace SQLiteDemo 
{ 
   class Program 
   { 
     static void Main(string[] args) 
     { 
       //CreateTable(); 
       //InsertData(); 
       ShowData(); 
       Console.ReadLine(); 
     } 
     public static void CreateTable() 
     { 
       string dbPath = "D:\\Demo.db3"; 
       //如果不存在改数据库文件,则创建该数据库文件 
       if (!System.I



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

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

  • C#解决SQlite并发异常问题的方法(使用读写锁)
  • C#操作SQLite数据库之读写数据库的方法
  • C# SQlite操作方法小结
  • C#操作SQLite数据库方法小结(创建,连接,插入,查询,删除等)
  • C#简单查询SQLite数据库是否存在数据的方法
  • C#简单访问SQLite数据库的方法(安装,连接,查询等)
  • C#操作SQLite方法实例详解
  • C#调用SQLite的方法实例分析
  • C#中嵌入SQLite数据库的简单方法
  • C#封装的Sqlite访问类实例

相关文章

  • 2017-05-28C#画笔Pen绘制光滑模式曲线的方法
  • 2017-05-28WinForm中的登录实现
  • 2017-05-28解析Silverlight调用WCF/Rest异常的解决方法
  • 2017-05-28C#中datagridview的EditingControlShowing事件用法实例
  • 2017-05-28C#数据结构之双向链表(DbLinkList)实例详解
  • 2017-05-28C#实现修改系统时间的方法
  • 2017-05-28C#画笔Pen保存和恢复图形对象的设置方法
  • 2017-05-28C#泛型编程介绍
  • 2017-05-28C#实现Winform鼠标拖动窗口大小时设定窗口最小尺寸的方法
  • 2017-05-28C#实现日期格式转换的公共方法类实例

文章分类

  • 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# WINFORM 强制让窗体获得焦点的方法代码
    • C#实现读取注册表监控当前操作系统已安装软件变化的方法
    • C#利用反射来判断对象是否包含某个属性的实现方法
    • 使用C#获取远程图片 Form用户名与密码Authorization认证的实现
    • 基于C#实现一个最简单的HTTP服务器实例
    • C#探秘系列(一)——ToDictionary,ToLookup
    • C#反色处理及其效率问题分析

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

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