让Sqlite脱离VC++ Runtime独立执行
前段时间在开发OrayTalk(傲瑞通企业即时通信系统)的聊天记录模块时用到了Sqlite,这是我第一次接触和使用Sqlite,整体感觉还是很不错的。这里把我使用Sqlite的经验跟大家分享一下。
一.关于Sqlite
Sqlite是一款开源的、适合在client和嵌入式设备中使用的轻量级数据库,支持标准的SQL。
不像SqlServer或Oracle的引擎是一个独立的进程、通过TCP或命名管道等与程序进行通信,SQLite却是作为程序的一个部件、一个构成部分,使用Sqlite的方式就是直接在程序中进行API调用。
原始的Sqlite是没有一个向SqlServer企业管理器的可视化操作程序的,可是有个第三方开发的应用SqliteStudio非常不错,主要的建库、建表、编辑数据、导出数据等功能都支持得非常好。SqliteStudio执行截图例如以下所看到的:
Sqlite资源链接:
(1)Sqlite官网:能够从官网下载源代码、或下载已经编译好的二进制版本号。支持的系统包含:Linux、MacOS、Windows、.NET。
(2)SqliteStudio:好用的Sqlite可视化管理器。
二.在.NET中使用Sqlite
从官网下载.NET版本号的Sqlite,其主要包含两个dll:SQLite.Interop.dll、System.Data.SQLite.dll。
(1)System.Data.SQLite.dll是一个标准的托管dll,我们能够直接在.NET项目中引用并使用它,就像使用.NET自带的System.Data命名空间中的各个对象一样。
(2)SQLite.Interop.dll是一个非托管的dll,是Sqlite引擎核心,我们须要将其复制到执行文件夹下,在执行时,它会被System.Data.SQLite.dll调用。
三.让Sqlite脱离VC++执行时
我们在项目开发完成后測试的过程中发现,使用了Sqlite的client程序在某些机器上执行时会报错,例如以下所看到的:
无法载入 DLL"SQLite.Interop.DLL";因为应用程序配置不对,应用程序未能启动。又一次安装应用程序可能会纠正这个问题。(异常来自 HRESULT:0x800736B1)
经过一番折腾,才发现是这些机器上没有安装VC++执行时(Visual C++ 2005 SP1 runtime),而SQLite.Interop.dll的执行是须要VC++执行时支持的。这点太不友好了。我们的项目是基于.NET 2.0开发的,windows xp sp1 及以上版本号都自带了这个Framework,而这些机器不一定安装了VC++执行时。所以我第一反应就是,尝试让Sqlite在没有安装VC++执行时的机器上也能正常执行。
1.方案一
我baidu了一下,有个似乎可行的方案是这种:将msvcm80.dll、msvcp80.dll、msvcr80.dll这几个动态库也放到执行文件夹下。这个方法我不太喜欢,于是我尝试自己动手解决这个问题。
2.方案二
凭借我还未全然忘记的一点VC++基础,我知道VC++程序在编译时能够选择是动态链接到依赖的库还是静态链接,假设是静态连接,编译生成的二进制程序中就相当于包括了一份依赖库的拷贝。所以,我的想法是,又一次编译SQLite.Interop.dll,使其静态链接到VC++执行库。我下载了Sqlite的源代码,用VS2010打开,截图例如以下:
SQLite.Interop.2010这个项目是核心,我们须要对它的一些设置略微做些改动,这些小改动我花了一些时间摸索才成功,这里就略去详细的摸索过程,直接给出摸索成果:
(1)打开SQLite.Interop.2010项目属性页面,配置属性 -> C/C++ -> 代码生成 -> 执行库,该项设置为 多线程调试 (/MTd)。
(2)继续 配置属性 -> 清单工具 -> 输入和输出 -> 嵌入清单,该项原来是“是”,改成“否”。
(3)显示全部项目文件,然后找到SQLite.Interop.2010.props文件,并打开。删掉当中的<INTEROP_MIXED_NAME>配置节点。
(4)从项目中移除“Resource Files”目录。
(5)又一次编译项目,生成的SQLite.Interop.dll便是我们所须要的。
四.下载成果
除非特别需求,否则大家没有必要反复这一过程,我把生成的Sqlite二进制版本号直接提供给大家下载使用。
让Sqlite脱离VC++ Runtime独立执行的更多相关文章
- 让Sqlite脱离VC++ Runtime独立运行
前段时间在开发OrayTalk(傲瑞通)的聊天记录模块时用到了Sqlite,这是我第一次接触和使用Sqlite,总体感觉还是非常不错的.这里把我使用Sqlite的经验跟大家分享一下. 一.关于Sqli ...
- CodedUI自己主动化測试及脱离VS独立执行
在VS中可创建"编码的UI測试".可录制软件操作,再回放,最后还能够脱离VS独立执行. 在VS中执行測试 创建项目codeuitest,控件布局.例如以下图: 在button单击事 ...
- 如何判断是否安装了VC RUNTIME
先得说下GUID,它是Globally Unique Identifier的简称,中文翻译为“全球唯一标示符”,在Windows系统中也称之为Class ID,缩写为CLSID.对于不同的应用程序,文 ...
- windows环境下把Python代码打包成独立执行的exe
windows环境下把Python代码打包成独立执行的exe可执行文件 有时候因为出差,突然急需处理一批数据.虽然写好的脚本存储在云端随用随取,然而编译的环境还需要重新搭建,模块也需要重新装载,从 ...
- windows环境下把Python代码打包成独立执行的exe可执行文件
有时候因为出差,突然急需处理一批数据.虽然写好的脚本存储在云端随用随取,然而编译的环境还需要重新搭建,模块也需要重新装载,从头到尾这么一遍下来,也是要花费可观的时间成本的. 有没有什么办法,可以让.p ...
- Spring框架 JdbcTemplate类 @Junit单元测试,可以让方法独立执行 如:@Test
package cn.zmh.PingCe; import org.junit.Test; import org.springframework.jdbc.core.BeanPropertyRowMa ...
- ADO方式,VC调用Execute执行INSERT INTO插入变量SQL语句的写法
ADO方式,VC调用Execute执行INSERT INTO插入变量SQL语句的写法 有些情况下,SQL SERVER 2008r2中需要保存float,int类型的数据,当C 中的变量为double ...
- 如何解决 An error occured executing the Microsoft VC+runtime installer
安装 postgresql 时遇见了 这个问题 There has been an error.An error occured executing the Microsoft VC+ runtim ...
- 一种脱离VC编程软件的方法学习C/C++编程(搭建EditPlus实现在文本编辑框中执行.c文件
网上下载一个EditPlus记事本安装好后就可以按照下面步骤进行搭建环境了: 一.工具(Tools)→配置用户工具(Configure UserTools...),[添加工具](Add Tool> ...
随机推荐
- phonegap+emberjs+python手机店发展,html5实现本地车类别~
商城开发项目,现在需要做出APP,无奈出场前android但不是很精通.最后选择phonegap实现app. 由于之前办理购物车分为登陆和登陆后两种情况,登录前必须充分利用本地存储.而基于phoneg ...
- Android - 用Fragments实现动态UI - 和其他Fragments通信
为了重用Fragment UI组件,应该把每个都设计为它自有的模块组件并且有自己的布局和行为.一旦定义了这些可重用的Fragment,你可以把它们和一个activity关联然后和程序的逻辑一起实现上层 ...
- C# WinForm dataGridView 技巧小结
1.不显示第一个空白列RowHeaderVisible属性设置为false 2.点击cell选取整行SelectinModel属性FullRowSelectRowSelectinModel属性设置或用 ...
- UVA 12206 - Stammering Aliens(后缀数组)
UVA 12206 - Stammering Aliens 题目链接 题意:给定一个序列,求出出现次数大于m,长度最长的子串的最大下标 思路:后缀数组.搞出height数组后,利用二分去查找就可以 这 ...
- FireFox VS Chrome 之 调试篇
一个完美的调试工具,FireBug! 精确跟踪每一步.仅仅要按下图所看到的,选择"脚本",然后在下方选择脚本所在的文件就可以对该文本的运行进行断点跟踪. 而且仅当一个线程运行结束后 ...
- 使用jQuery和css3实现了仿淘宝ued博客左边的菜单切换动画
今天看到淘宝ued博客的左侧导航菜单的动画好,要使用jQuery和css3我做一个简单的示例,主要用途是实现jQuery 事件和css3 transition属性. 个元素来实现鼠标滑动到某个导航的背 ...
- KindEditor参数具体解释
width 编辑器的宽度.能够设置px或%.比textarea输入框样式表宽度优先度高. 数据类型: String 默认值: textarea输入框的宽度 演示样例: K.create('#id', ...
- 实现BUG自动检测 - ASP.NET Core依赖注入
我个人比较懒,能自动做的事绝不手动做,最近在用ASP.NET Core写一个项目,过程中会积累一些方便的工具类或框架,分享出来欢迎大家点评. 如果以后有时间的话,我打算写一个系列的[实现BUG自动检测 ...
- Ubuntu文件的复制、移动和删除命令
先说说cp复制命令 该命令的功能是将给出的文件或文件夹复制到还有一文件或文件夹中,同MSDOS下的copy命令一样,功能十分强大. 语法: cp [选项] 源文件或文件夹 目标文件或文件夹 说明:该命 ...
- Android高级编程笔记(四)深入探讨Activity(转)
在应用程序中至少包含一个用来处理应用程序的主UI功能的主界面屏幕.这个主界面一般由多个Fragment组成,并由一组次要Activity支持.要在屏幕之间切换,就必须要启动一个新的Activity.一 ...