C#中使用SQLite

(1) 从下面的网址下载了 SQLite 版本(sqlite-netFx40-setup-bundle-x64-2010-1.0.83.0):
http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

安 .cs 文件中使用了 using:using System.Data.SQLite;

增加代码:SQLiteConnection.CreateFile(dataSource); 运行时报错如下(第一次使用C#,请各位帮忙分析一下出错的原因):

未处理 System.BadImageFormatException
  Message=未能加载文件或程序集“System.Data.SQLite, Version=1.0.83.0, Culture=neutral,

PublicKeyToken=db937bc2d44ff139”或它的某一个依赖项。试图加载格式不正确的程序。
  Source=UseSQLite
  FileName=System.Data.SQLite, Version=1.0.83.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139
  FusionLog==== 预绑定状态信息 ===
日志: 用户 = yonghang-PC\yonghang
日志: DisplayName = System.Data.SQLite, Version=1.0.83.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139
 (Fully-

specified)
日志: Appbase = file:///E:/Source/PC/UseSQLite/bin/Debug/
日志: 初始 PrivatePath = NULL
调用程序集: UseSQLite, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null。
===
日志: 此绑定从 default 加载上下文开始。
日志: 未找到应用程序配置文件。
日志: 使用主机配置文件: 
日志: 使用 C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config 的计算机配置文件。
日志: 策略后引用: System.Data.SQLite, Version=1.0.83.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139
日志: 尝试下载新的 URL file:///E:/Source/PC/UseSQLite/bin/Debug/System.Data.SQLite.DLL。
错误: 未能完成程序集的安装(hr = 0x8007000b)。探测终止。

StackTrace:
       在 UseSQLite.Form1.CreateSqliteDatabase()
       在 UseSQLite.Form1..ctor() 位置 E:\Source\PC\UseSQLite\Form1.cs:行号 22
       在 UseSQLite.Program.Main() 位置 E:\Source\PC\UseSQLite\Program.cs:行号 18
       在 System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
       在 System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
       在 Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
       在 System.Threading.ThreadHelper.ThreadStart_Context(Object state)
       在 System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object

state, Boolean ignoreSyncCtx)
       在 System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object

state)
       在 System.Threading.ThreadHelper.ThreadStart()
  InnerException:

代码:

 1 using System;
 2 using System.Collections.Generic;
 3 using System.ComponentModel;
 4 using System.Data;
 5 using System.Drawing;
 6 using System.Linq;
 7 using System.Text;
 8 using System.Windows.Forms;
 9
10 using System.Data.SQLite;
11
12 namespace UseSQLite
13 {
14     public partial class Form1 : Form
15     {
16         private string dataSource = "UseSQLite.sqlite";
17         //private string dataSource = "E:/Source/PC/SQliteDB.db";
18
19         public Form1()
20         {
21             InitializeComponent();
22
23             CreateSqliteDatabase();
24         }
25
26         void CreateSqliteDatabase()
27         {
28             System.Diagnostics.Debug.WriteLine("Use SQLite: start create database...");
29             SQLiteConnection.CreateFile(dataSource);
30 //             SQLiteConnection conn = new SQLiteConnection();
31 //             SQLiteConnectionStringBuilder connstr = new SQLiteConnectionStringBuilder();
32 //             connstr.DataSource = dataSource;
33 //             connstr.Password = "admin"; //设置密码,SQLite ADO.NET实现了数据库密码保护
34 //             conn.ConnectionString = connstr.ToString();
35 //             conn.Open();
36             System.Diagnostics.Debug.WriteLine("Use SQLite: create database end.");
37         }
38     }
39 }  

CSDN友回复可能是因为以下原因:
有可能是框架配置不正确,SQLite是.NET 4.0,而你的控制台为.NET 4.0 Client Profile;
.NET 4.0 大于 .NET 4.0 Client Profile 查看项目属性,更改试试.
 .NET 4.0 Client Profile比.NET 4.0占用的空间要小,但支持的类型也比.NET 4.0支持的类型小。
SQLITE的动态库是.NET 4.0 Client Profile不支持的。
未验证是否是这样。

(2) 下载了:SQLite-1.0.66.0-setup.exe,安装后在 VS2010 的菜单“增加新数据源”的“新建连接...”中终于找到了 SQLite 的选项。
然后需要将工程的目标框架由 4.0 修改为 3.5,否则编译报错。
最后,在工程中“增加引用”,选择 \SQLite.NET\bin 目录的:System.Data.SQLite.dll和System.Data.SQLite.dll(可选)

(3) 创建数据库

......

------------------------------------------------------------------------------------------------

* 从 http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki 下载了 sqlite-netFx35-setup-bundle-x86-2008-1.0.83.0.exe
 * 为 VS2008 版本,安装。安装过程中,在 console 界面提示了一些错误,最后安装完成。
 * 在 VS2008 中新建一个 C# 的工程,"Add References..." 浏览到 sqlite-netFx35-setup-bundle-x86-2008-1.0.83.0.exe 的安装目录
 * 例如,我的安装目录:D:\Program Files\System.Data.SQLite\2008\bin
 * 选择 System.Data.SQLite.dll,在工程的 References 中可以看到多了一个: System.Data.SQLite
 * 在工程的 Form1.cs 中增加: using System.Data.SQLite;
 * 增加代码如下:

* 编译调试通过,引起问题的原因如 CSDNer 所说的 .Net 版本选择不对,导致前天测试一直通不过。

 1 using System.Data.SQLite;
 2
 3 namespace TestUseSqlite
 4 {
 5     public partial class Form1 : Form
 6     {
 7         private string dataSource = "ContactBookDB.sqlite";
 8
 9         public Form1()
10         {
11             InitializeComponent();
12
13             SQLiteConnection.CreateFile(dataSource);
14
15             SQLiteConnection dbConn = new SQLiteConnection("Data Source=" + dataSource);
16
17             dbConn.Open();
18
19             SQLiteCommand dbCmd = dbConn.CreateCommand();
20
21             dbCmd.CommandText = "CREATE TABLE TelephoneBook(personID varchar(20),telephone varchar(30),type varchar(20))";
22             dbCmd.ExecuteNonQuery();
23
24             dbCmd.CommandText = "INSERT INTO TelephoneBook VALUES(‘MTB‘,‘1234567890‘,‘not mobile‘)";
25             dbCmd.ExecuteNonQuery();
26
27             dbCmd.CommandText = "SELECT * FROM TelephoneBook";
28             SQLiteDataReader dataReader = dbCmd.ExecuteReader();
29
30             DataTable dataTable = new DataTable();
31             if (dataReader.HasRows)
32             {
33                 dataTable.Load(dataReader);
34             }
35
36             dataGridView1.DataSource = dataTable;
37
38             dataReader.Close();
39             dbConn.Close();
40         }
41     }
42 }  
时间: 2024-12-08 22:04:20

C#中使用SQLite的相关文章

sqlite学习笔记8:C语言中使用sqlite之创建表

前面已经说了如何打开和关闭数据库,这次要说得是如何执行SQL语句,来创建一张表. 要用的的函数: sqlite3_exec(sqlite3* db, const char *sql, sqlite_callback callback, void *data, char **errmsg) 参数: db:已经打开的数据库实例 sql:SQL语句,是一个字符串 callback:是一个回调函数 data:做为回调函数的第一个参数 errmsg:用于带回错误信息 该回调函数有两种返回值类型. 1.返回

Go语言中使用SQLite数据库

Go语言中使用SQLite数据库 1.驱动 Go支持sqlite的驱动也比较多,但是好多都是不支持database/sql接口的 https://github.com/mattn/go-sqlite3 支持database/sql接口,基于cgo(关于cgo的知识请参看官方文档或者本书后面的章节)写的 https://github.com/feyeleanor/gosqlite3 不支持database/sql接口,基于cgo写的 https://github.com/phf/go-sqlite

Android中使用Sqlite数据库 (一) 建表

一.实现一个类,继承SQLiteOpenHelper类,并实现构造函数,onCreate()  onUpgrade() import android.content.Context; import android.database.DatabaseErrorHandler; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; impo

Android中使用Sqlite数据库 (二) 增删改查

定义接口 package com.example.android_db.service; import java.util.List; import java.util.Map; public interface PersonService { public boolean addPerson(Object[] params); public boolean deletePerson(Object[] params); public boolean updatePerson(Object[] p

在Android中利用SQLite实现对数据的增删查改

停更了一天,I'm back again~~当我们需要操作大量的数据时,我们首先想到的当然是数据库,因为可以通过简单的语句实现数据的增删改查,在Android中,我们不使用SQL或者ORACLE,我们使用SQLite,因为它占用资源更少,而语句格式与SQL语句一样. 首先,我们来在Android中实现数据库的创建与增删改查,引用数据库的类时,不再继承常用的Activity类,而是继承Android中的SQLiteOpenHelper,创建一个构造方法,四个参数分别是(Context contex

Swift中使用SQLite的配置方法

Swift 中使用 SQLite 1.准备工作 添加 libsqlite3.dylib 创建 SQLite-Bridge.h SQLite3 框架是一套 C 语言的框架,因此需要添加桥接文件 选择 项目-TARGETS-Build Settings,搜索 Bridg 在 Objective-C Bridging Header 中输入 项目名/SQLite-Bridge.h 如果之前设置过桥接文件,可以直接使用 导入SQLite3.thd头文件 导入成功

sqlite学习笔记9:C语言中使用sqlite之插入数据

前面创建了一张表,现在给他插入一些数据,插入数据跟创建表差不多,仅仅是SQL语言不一样而已,完整代码如下: #include <stdio.h> #include <stdlib.h> #include "sqlite/sqlite3.h" #define DB_NANE "sqlite/test.db" sqlite3 *db = NULL; char* sql = NULL; char *zErrMsg = NULL; int ret =

sqlite学习笔记10:C语言中使用sqlite之查询和更新数据

前面说到的 sqlite_exec() 中的第三个参数, SQLite 将为 sql 参数内执行的每个 SELECT 语句中处理的每个记录调用这个回调函数. 本节添加了两个函数,selectFromTable和updateTable. 实例程序如下: #include <stdio.h> #include <stdlib.h> #include "sqlite/sqlite3.h" #define DB_NANE "sqlite/test.db&quo

sqlite学习笔记11:C语言中使用sqlite之删除记录

最后一节,这里记录下如何删除数据. 前面所有的代码都继承在这里了,在Ubuntu14.04和Mac10.9上亲测通过. #include <stdio.h> #include <stdlib.h> #include "sqlite/sqlite3.h" #define DB_NANE "sqlite/test.db" sqlite3 *db = NULL; char* sql = NULL; char *zErrMsg = NULL; con

2014-08-01 ASP.NET中对SQLite数据库的操作——ADO.NET

今天是在吾索实习的第18天.我主要学习了如何在ASP.NET中对SQLite数据库的操作,其基本操作如下: 添加引用System.Data.SQLite.dll(PS:在网页里面任意找到适合的.NET Framework版本与位数所对应的压缩包,里面就会有该文件了). 在所在cs文件中加入using System.Data.SQLite; 定义两个string变量:ConStr.SqlStr,分别用于SQLite的连接字符串与SQL语句. 定义SQLiteConnection变量Conn,用于连