zoukankan      html  css  js  c++  java
  • 让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二进制版本号直接提供给大家下载使用。

      能脱离VC++执行时执行的Sqlite (v1.0.93.0)  

     

  • 相关阅读:
    Web--js高级--12月19日随笔
    Web--js高级--12月18日随笔
    Web--js高级--12月17日随笔
    Web--js高级--关于所学闭包随笔
    Web--js高级--12月10日随笔
    Web--js高级--12月4日随笔
    Web--js高级--12月3日随笔
    微信小程序预览图片
    开发微信“小程序”必学教程
    navigator 页面链接
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/4270117.html
Copyright © 2011-2022 走看看