C#使用System.Data.SQLite操作SQLite

使用System.Data.SQLite 下载地址:http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

得到System.Data.SQLite.dll添加到工程引用;

建表,插入操作

  1. static void Main(string[] args)
  2. {
  3. SQLiteConnection conn = null;
  4. string dbPath = "Data Source =" + Environment.CurrentDirectory + "/test.db";
  5. conn = new SQLiteConnection(dbPath);//创建数据库实例,指定文件位置
  6. conn.Open();//打开数据库,若文件不存在会自动创建
  7. string sql = "CREATE TABLE IF NOT EXISTS student(id integer, name varchar(20), sex varchar(2));";//建表语句
  8. SQLiteCommand cmdCreateTable = new SQLiteCommand(sql, conn);
  9. cmdCreateTable.ExecuteNonQuery();//如果表不存在,创建数据表
  10. SQLiteCommand cmdInsert = new SQLiteCommand(conn);
  11. cmdInsert.CommandText = "INSERT INTO student VALUES(1, ‘小红‘, ‘男‘)";//插入几条数据
  12. cmdInsert.ExecuteNonQuery();
  13. cmdInsert.CommandText = "INSERT INTO student VALUES(2, ‘小李‘, ‘女‘)";
  14. cmdInsert.ExecuteNonQuery();
  15. cmdInsert.CommandText = "INSERT INTO student VALUES(3, ‘小明‘, ‘男‘)";
  16. cmdInsert.ExecuteNonQuery();
  17. conn.Close();
  18. }

  可以使用SQLite Database Browser来查看数据:

下载地址:http://sourceforge.net/projects/sqlitebrowser/

     建表成功。

当然这种方法插入数据效率不高,数据量大的话要使用下面这种方法:

  1. static void Main(string[] args)
  2. {
  3. string dbPath = Environment.CurrentDirectory + "/test.db";//指定数据库路径
  4. using(SQLiteConnection conn = new SQLiteConnection("Data Source =" + dbPath))//创建连接
  5. {
  6. conn.Open();//打开连接
  7. using(SQLiteTransaction tran = conn.BeginTransaction())//实例化一个事务
  8. {
  9. for (int i = 0; i < 100000; i++ )
  10. {
  11. SQLiteCommand cmd = new SQLiteCommand(conn);//实例化SQL命令
  12. cmd.Transaction = tran;
  13. cmd.CommandText = "insert into student values(@id, @name, @sex)";//设置带参SQL语句
  14. cmd.Parameters.AddRange(new[] {//添加参数
  15. new SQLiteParameter("@id", i),
  16. new SQLiteParameter("@name", "中国人"),
  17. new SQLiteParameter("@sex", "男")
  18. });
  19. cmd.ExecuteNonQuery();//执行查询
  20. }
  21. tran.Commit();//提交
  22. }
  23. }
  24. }

插入这样的十万条数据只需要5秒左右。

读取数据:

  1. static void Main(string[] args)
  2. {
  3. SQLiteConnection conn = null;
  4. string dbPath = "Data Source =" + Environment.CurrentDirectory + "/test.db";
  5. conn = new SQLiteConnection(dbPath);//创建数据库实例,指定文件位置
  6. conn.Open();//打开数据库,若文件不存在会自动创建
  7. string sql = "select * from student";
  8. SQLiteCommand cmdQ = new SQLiteCommand(sql, conn);
  9. SQLiteDataReader reader = cmdQ.ExecuteReader();
  10. while (reader.Read())
  11. {
  12. Console.WriteLine(reader.GetInt32(0) + " " + reader.GetString(1) + " " + reader.GetString(2));
  13. }
  14. conn.Close();
  15. Console.ReadKey();
  16. }

  数据读取成功。

原文链接:http://www.cnblogs.com/gc2013/p/3806257.html

C#使用System.Data.SQLite操作SQLite,布布扣,bubuko.com

时间: 2024-10-07 06:17:15

C#使用System.Data.SQLite操作SQLite的相关文章

python---基础知识回顾(八)数据库基础操作(sqlite和mysql)

一:sqlite操作 SQLite是一种嵌入式数据库,它的数据库就是一个文件.由于SQLite本身是C写的,而且体积很小,所以,经常被集成到各种应用程序中,甚至在iOS和Android的App中都可以集成. Python就内置了SQLite3,所以,在Python中使用SQLite,不需要安装任何东西,直接使用. 操作步骤: 1.创建连接(记得导入模块) import sqlite3 conn = sqlite3.connect("test.db") #若是文件不存在会自动创建,路径可

System.Data.SQLite数据库简介

SQLite介绍 在介绍System.Data.SQLite之前需要介绍一下SQLite,SQLite是一个类似于Access的单机版数据库管理系统,它将所有数据库的定义(包括定义.表.索引和数据本身)都保存在一个单一的文件中.并且,SQLite是一个用C实现的类库,它在内存消耗.文件体积.简单性方面都有不错的表现,如果数据在10W条以下,查询速度也是相当快的.SQLite具有以下特征:实现多数SQL92的标准,包括事务(原子性.一致性.隔离性和持久性).触发器和大多数的复杂查询.不对插入或者更

System.Data.SQLite

SQLite介绍 在介绍System.Data.SQLite之前需要介绍一下SQLite,SQLite是一个类似于Access的单机版数据库管理系统,它将所有数据库的定义(包括定义.表.索引和数据本身)都保存在一个单一的文件中.并且,SQLite是一个用C实现的类库,它在内存消耗.文件体积.简单性方面都有不错的表现,如果数据在10W条以下,查询速度也是相当快的. SQLite具有以下特征: 实现多数SQL92的标准,包括事务(原子性.一致性.隔离性和持久性).触发器和大多数的复杂查询. 不对插入

引用64位dll时候出现 未能加载文件或程序集“System.Data.SQLite”或它的某一个依赖项。试图加载格式不正确的程序。

引用64位dll时候出现 未能加载文件或程序集“System.Data.SQLite”或它的某一个依赖项.试图加载格式不正确的程序. 需要在web.config增加配置 <startup useLegacyV2RuntimeActivationPolicy="true"> <supportedRuntime version="v4.0"/> </startup>

未找到具有固定名称&ldquo;System.Data.SQLite&rdquo;的 ADO.NET 提供程序的实体框架提供程序

用户代码未处理 System.InvalidOperationException   HResult=-2146233079   Message=未找到具有固定名称"System.Data.SQLite"的 ADO.NET 提供程序的实体框架提供程序.请确保在应用程序配置文件的"entityFramework"节中注册了该提供程序.有关详细信息,请参阅 http://go.microsoft.com/fwlink/?LinkId=260882.   Source=E

Could not load file or assembly&#39;System.Data.SQLite.dll&#39; or one of its depedencies

[问题]  在我本机的开发环境c#连接sqlite3没有问题,可是release版本移植到其他的机器就提示Could not load file or assembly'System.Data.SQLite.dll' or one of its depedencies.找不到指定模块. [解决] 搜来搜去没找到靠谱的答案,其实最后还是自己解决的. sqlite官方的下载页面里面说了:The Visual C++ 2010 SP1 runtime for x86 and the .NET Fr

Win7 64bit系统WinFrom下未能加载文件或程序集“System.Data.SQLite”的解决办法

在Win7 64bit系统下调试程序时出现如下错误: 未能加载文件或程序集”System.Data.SQLite”或它的某一个依赖项.试图加载格式不正确的程序. 事实上System.Data.SQLite.dll控件在默认情况下是32bit的,在64bit系统下得使用另一个控件. 可以到这里http://sourceforge.net/projects/sqlite-dotnet2/files/下载一个安装程序包,安装完后在D:\Program Files (x86)\SQLite.NET\bi

“System.BadImageFormatException”类型的未经处理的异常在 PurchaseDevices.Access.dll 中发生 其他信息: 未能加载文件或程序集“System.Data.SQLite, Version=1.0.66.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139”或它的某一个依赖项。试图加载格式不正确

引用sqlite的程序集时,有时会报如下异常: "System.BadImageFormatException"类型的未经处理的异常在 PurchaseDevices.Access.dll 中发生 其他信息: 未能加载文件或程序集"System.Data.SQLite, Version=1.0.66.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139"或它的某一个依赖项.试图加载格式不正确的程序. 解决方案:在配置

System.Data.SQLite兼容32位和64位问题

SQLite版本分的很详细,本机是64位在32位会出现问题,经过搜索找到解决方案. 这是我以前写的32位在我现在的机子上的运行报错. 类似这样的. 将当前说明文档的目录下的x64.x86目录和System.Data.SQLite.dll文件复制到您的应用程序根目录中(注意更新引用,引用System.Data.SQLite.dll即可,两目录中的不需要引用,但发布时需打包).如果是WEB网站,则复制到Bin目录下即可,发布时,也注意x64和x86一起打包发布 注意,当前的System.Data.S