之所以要做这个笔记,是因为在.NET中使用System.Data.SQLite的时候,遇到了些问题,这些问题是相对于引用其他dll没有遇到过的,所以作个笔记,记录一下。

简单起见,首先建立一个控制台项目,这肯定是.NET4.5以上的版本了,我用的是vs2017,其他版本的vs在引用System.Data.SQLite的时候有没有问题,这个就不得而知了。

首先还是按照以往使用第三方dll文件(指是在引用管理器中搜索不到的dll)的思路,在项目文件夹下面建立一个文件夹dll,将System.Data.SQLite.dll放进去(前提是保证下载的dll是正确的版本),然后

在项目中添加这个dll的引用。然后在项目的main函数中粘贴以下代码,这里只是为了能正常使用SQLite,所以代码设计的比较简单,当然代码也是网上找的

SQLiteConnection conn = null;  

            string dbPath = "Data Source =" + Environment.CurrentDirectory + "/test.db";
conn = new SQLiteConnection(dbPath);//创建数据库实例,指定文件位置
conn.Open();//打开数据库,若文件不存在会自动创建 string sql = "CREATE TABLE IF NOT EXISTS student(id integer, name varchar(20), sex varchar(2));";//建表语句
SQLiteCommand cmdCreateTable = new SQLiteCommand(sql, conn);
cmdCreateTable.ExecuteNonQuery();//如果表不存在,创建数据表 SQLiteCommand cmdInsert = new SQLiteCommand(conn);
cmdInsert.CommandText = "INSERT INTO student VALUES(1, '小红', '男')";//插入几条数据
cmdInsert.ExecuteNonQuery();
cmdInsert.CommandText = "INSERT INTO student VALUES(2, '小李', '女')";
cmdInsert.ExecuteNonQuery();
cmdInsert.CommandText = "INSERT INTO student VALUES(3, '小明', '男')";
cmdInsert.ExecuteNonQuery(); conn.Close();

然后开始跑程序,出现了第一个问题:异常来自 HRESULT:0x8007000B

网上搜索了一下解决方案,都说的是将项目属性里面的生成里面的平台目标改成x86或x64。再啰嗦一句,我的电脑系统是Windows server 2012 r2 标准版,妥妥的64位操作系统。

这里我选择的是x86,然后继续跑程序,结果还是出现刚才的问题。然后选择x64,跑程序。好了,这回出现新问题了:异常来自 HRESULT:0x8007007E

根据提示,说是没有SQLite.Interop.dll文件,于是将这个文件复制到刚才建立的dll文件夹中,并引进项目,结果又出问题了。不就是引用个第三方的dll文件吗,有必要出现那么多问题吗,内心已经很崩溃。

这个问题,我确实没办法了,网上也找不到合适的解决方案(主要是有些解决办法太麻烦,看都懒得看了)。怎么办呢,遇到问题总要解决吧,作为一个专业的程序员,码农,遇到问题必须有探索的精神,

不能指望领导,不能指望同事,想想自己还没赚到足够的钱,娶到白富美,走上人生的巅峰,想想家里的父母.......开始胡思乱想了。想着想着,无意中打开了项目的bin文件夹里面的Debug文件夹,哎哟我

去,发现了新大陆了,这个dll怎么出现在这里,我明明是放在dll文件夹里面的。再想到刚才的错误不是说没有SQLite.Interop.dll文件吗,那我把SQLite.Interop.dll文件也放到这里看看

再跑程序,哎哟我去,奇迹出现了,程序跑起来了,成功了,debug文件夹下,出现了test.db文件了,这不就是梦中情人白富美吗,总算出现了。

为了验证一下是否真的把数据写进去了,我简单些了个查询函数看了一下,果然没问题

总结:1、下载正确版本的SQLite,主要是32位还是64位

    2、将SQLite.Interop.dll和System.Data.SQLite.dll放到bin文件夹的debug文件夹下,然后只需引用System.Data.SQLite.dll就好

       3、将项目属性里面的生成里面的平台目标改成x64,当然这是因为我电脑是64位的,如果是32位电脑也许不用这步操作了。

一般来说,这样的对数据库的操作的代码,都是写在类库里面的,这里就有个地方需要注意了,在编写对SQLite使用的类库的时候,在类库中只需引用System.Data.SQLite.dll,文件放在什么地方无所谓,

只要能引用就行,然后编译通过后,在引用这个类库的项目里面,记得将SQLite.Interop.dll放到bin文件夹下面的debug文件夹,而且引用的项目的属性里面的平台目标记得改成x64。而类库没有这个要求。

.net引用System.Data.SQLite操作SQLite的更多相关文章

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

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

  2. System.Data.OleDb操作access数据库类,【bubuko.com】

    access数据库在应用了System.Data.OleDb后操作会很方便,这是一个常用的数据库操作类,其中两个方法,一个是返回datatable的,一个是执行sql语句返回影响记录的(一般是inse ...

  3. C#------引用System.Data.Entity后DbContext依然无法继承解决方法

    解决方法: 需要在“引用”->“管理NuGet程序包”里面添加->“EntityFramework.dll”文件即可

  4. 【转】VS2010不能引用System.Data.OracleClient解决方法

    源地址:http://blog.csdn.net/iloli/article/details/8484674

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

    将当前说明文档的目录下的x64.x86目录和System.Data.SQLite.dll文件复制到您的应用程序根目录中(注意更新引用,引用System.Data.SQLite.dll即可,两目录中的不 ...

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

    SQLite版本分的很详细,本机是64位在32位会出现问题,经过搜索找到解决方案. 这是我以前写的32位在我现在的机子上的运行报错. 类似这样的. 将当前说明文档的目录下的x64.x86目录和Syst ...

  7. 手把手教你使用C#操作SQLite数据库,新建数据库,创建表,插入,查询,删除,运算符,like

    目录: 一.新建项目,添加引用 二.创建数据库 三.创建表 四.插入数据  五.查询数据  六.删除数据  七.运算符 八.like语句 我的环境配置:windows 64,VS,SQLite(点击下 ...

  8. C#操作Sqlite快速入门及相关工具收集

    Sqlite不需要安装即可使用.Sqlite是不是那个System.Data.SQLite.DLL临时创建了数据库引擎? 1.新建一个WinForm项目,引用System.Data.SQLite.DL ...

  9. c#操作sqlite db3数据库

    首先添加引用 System.Data.SQLite.dll,引用只用添加这个,但SQLite.Interop.dll文件必须也和它同时放在Debug目录下 然后可用: SQLiteConnection ...

随机推荐

  1. HDU 2222 (AC自动机)

    HDU 2222 Keywords search Problem : 给若干个模式串,询问目标串中出现了多少个模式串. Solution : 复习了一下AC自动机.需要注意AC自动机中的fail,和n ...

  2. 利用mysql分析小规模数据

    1 获取数据 示例:(/home/work/data/1.data) 123457,chenli,70 123458,liuyang,71 2 create table CREATE TABLE sc ...

  3. POJ 2431 Expedition【贪心】

    题意: 卡车每走一个单元消耗一升汽油,中途有加油站,可以进行加油,问能否到达终点,求最少加油次数. 分析: 优先队列+贪心 代码: #include<iostream> #include& ...

  4. P1230 智力大冲浪 洛谷

    https://www.luogu.org/problem/show?pid=1230 题目描述 小伟报名参加中央电视台的智力大冲浪节目.本次挑战赛吸引了众多参赛者,主持人为了表彰大家的勇气,先奖励每 ...

  5. Maven项目中遇到的奇葩问题(续)

    场景描写叙述 开发项目搞环境是一个很蛋疼的问题.总是会遇到各种奇葩的问题,上一篇文章http://blog.csdn.net/gao36951/article/details/50955526中遇到的 ...

  6. 使用Swift模拟Window-LFU

    今天參加了某公司2015的校招的机试,大题开放题比較多.有一道大题是Window-LFU比較有意思,当时题目搞了半天没搞明确让干啥- -题目大概是这种:实现一个Window-LFU缓存(事实上就是用数 ...

  7. HDU 5319 Painter(枚举)

    Painter Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Su ...

  8. 让你完全理解base64是怎么回事

    HTTP将BASE64-编码用于基本认证和摘要认证,在几种HTTP扩展中也使用了该编码. Base-64编码保证了二进制数据的安全 Base-64编码可以将任意一组字节转换为较长的常见文本字符序列,从 ...

  9. iOS动画案例(1) 仿qq账号信息里的一个动画

       受人所托,模仿qq账号信息里的一个动画,感觉挺有意思,也没感觉有多难,就开始做了,结果才发现学的数学知识都还给体育老师了,研究了大半天才做出来.    先看一下动画效果:   用到的知识点: ( ...

  10. 约瑟夫环问题(Josephus)

    约瑟夫环:用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至最后一个元素并输出该元素的值. 一.循环链表:建立一个有N个元素的循环链表,然后从链表头开始遍历并记数,如果计数值为M,则 ...