濮阳杆衣贸易有限公司

主頁 > 知識庫 > 讓Sqlite脫離VC++ Runtime獨立運行的方法

讓Sqlite脫離VC++ Runtime獨立運行的方法

熱門標(biāo)簽:浦發(fā)電話機(jī)器人提醒還款 400電話如何申請取消 柳州電銷機(jī)器人公司 百度地圖怎樣做地圖標(biāo)注 騰訊地圖標(biāo)注手機(jī) 征途美甲店地圖標(biāo)注 電銷語音機(jī)器人型號參數(shù) 昆明語音電銷機(jī)器人價格 太原400電話上門辦理

目前手頭上的一個.NET項目用到了Sqlite,這是我第一次接觸和使用Sqlite,總體感覺還是非常不錯的。這里把我使用Sqlite的經(jīng)驗跟大家分享一下。

一.關(guān)于Sqlite  

  Sqlite是一款開源的、適合在客戶端和嵌入式設(shè)備中使用的輕量級數(shù)據(jù)庫,支持標(biāo)準(zhǔn)的SQL。

  不像SqlServer或Oracle的引擎是一個獨立的進(jìn)程、通過TCP或命名管道等與程序進(jìn)行通信,SQLite卻是作為程序的一個部件、一個構(gòu)成部分,使用Sqlite的方式就是直接在程序中進(jìn)行API調(diào)用。

  原始的Sqlite是沒有一個向SqlServer企業(yè)管理器的可視化操作程序的,但是有個第三方開發(fā)的應(yīng)用SqliteStudio非常不錯,基本的建庫、建表、編輯數(shù)據(jù)、導(dǎo)出數(shù)據(jù)等功能都支持得很好。SqliteStudio運行截圖如下所示:

Sqlite資源鏈接:

(1)Sqlite官網(wǎng):可以從官網(wǎng)下載源碼、或下載已經(jīng)編譯好的二進(jìn)制版本。支持的系統(tǒng)包括:Linux、MacOS、Windows、.NET。

(2)SqliteStudio:好用的Sqlite可視化管理器。

二.在.NET中使用Sqlite

  從官網(wǎng)下載.NET版本的Sqlite,其主要包括兩個dll:SQLite.Interop.dll、System.Data.SQLite.dll。

(1)System.Data.SQLite.dll是一個標(biāo)準(zhǔn)的托管dll,我們可以直接在.NET項目中引用并使用它,就像使用.NET自帶的System.Data命名空間中的各個對象一樣。

(2)SQLite.Interop.dll是一個非托管的dll,是Sqlite引擎核心,我們需要將其拷貝到運行目錄下,在運行時,它會被System.Data.SQLite.dll調(diào)用。

三.讓Sqlite脫離VC++運行時

  我們在項目開發(fā)完畢后測試的過程中發(fā)現(xiàn),使用了Sqlite的客戶端程序在某些機(jī)器上運行時會報錯,如下所示:

  無法加載 DLL"SQLite.Interop.DLL";由于應(yīng)用程序配置不正確,應(yīng)用程序未能啟動。重新安裝應(yīng)用程序可能會糾正這個問題。(異常來自 HRESULT:0x800736B1)

  經(jīng)過一番折騰,才發(fā)現(xiàn)是這些機(jī)器上沒有安裝VC++運行時(Visual C++ 2005 SP1 runtime),而SQLite.Interop.dll的運行是需要VC++運行時支持的。這點太不友好了。我們的項目是基于.NET 2.0開發(fā)的,windows xp sp1 及以上版本都自帶了這個Framework,而這些機(jī)器不一定安裝了VC++運行時。所以我第一反應(yīng)就是,嘗試讓Sqlite在沒有安裝VC++運行時的機(jī)器上也能正常運行。

1.方案一

  我baidu了一下,有個似乎可行的方案是這樣的:將msvcm80.dll、msvcp80.dll、msvcr80.dll這幾個動態(tài)庫也放到運行目錄下。這個方案我不太喜歡,于是我嘗試自己動手解決問題。

2.方案二

  憑借我還未完全忘記的一點VC++基礎(chǔ),我知道VC++程序在編譯時可以選擇是動態(tài)鏈接到依賴的庫還是靜態(tài)鏈接,如果是靜態(tài)連接,編譯生成的二進(jìn)制程序中就相當(dāng)于包含了一份依賴庫的拷貝。所以,我的想法是,重新編譯 SQLite.Interop.dll,使其靜態(tài)鏈接到VC++運行庫。我下載了Sqlite的源碼,用VS2010打開,截圖如下:

     

   SQLite.Interop.2010這個項目是核心,我們需要對它的一些設(shè)置稍微做些修改,這些小修改我花了一些時間摸索才成功,這里就略去具體的摸索過程,直接給出摸索成果:

(1)打開SQLite.Interop.2010項目屬性頁面,配置屬性 -> C/C++ -> 代碼生成 -> 運行庫,該項設(shè)置為 多線程調(diào)試 (/MTd)。

(2)繼續(xù) 配置屬性 -> 清單工具 -> 輸入和輸出 -> 嵌入清單,該項原來是“是”,改成“否”。

(3)顯示所有項目文件,然后找到SQLite.Interop.2010.props文件,并打開。刪掉其中的INTEROP_MIXED_NAME>配置節(jié)點。

(4)從項目中移除“Resource Files”文件夾。

(5)重新編譯項目,生成的SQLite.Interop.dll便是我們所需要的。

 四.下載成果

  除非特別需求,否則大家沒有必要重復(fù)這一過程,我把生成的Sqlite二進(jìn)制版本直接提供給大家下載使用。

補(bǔ)充:Sqlite官網(wǎng)已經(jīng)提供靜態(tài)連接的庫了
http://system.data.sqlite.org/downloads/1.0.93.0/sqlite-netFx20-static-binary-bundle-Win32-2005-1.0.93.0.zip

您可能感興趣的文章:
  • c++獲取sqlite3數(shù)據(jù)庫表中所有字段的方法小結(jié)
  • SQLite教程(二):C/C++接口簡介
  • VC++操作SQLite簡單實例
  • C++操作SQLite簡明教程
  • C++ Sqlite3的使用方法

標(biāo)簽:蘭州 德陽 陽泉 江蘇 白山 張家界 新疆 天門

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《讓Sqlite脫離VC++ Runtime獨立運行的方法》,本文關(guān)鍵詞  讓,Sqlite,脫離,VC++,Runtime,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《讓Sqlite脫離VC++ Runtime獨立運行的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于讓Sqlite脫離VC++ Runtime獨立運行的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    上杭县| 靖远县| 元朗区| 三河市| 鞍山市| 灌云县| 湾仔区| 清涧县| 淮北市| 四子王旗| 都昌县| 诸城市| 汉中市| 桐庐县| 扎鲁特旗| 铜川市| 山西省| 项城市| 泽库县| 新丰县| 屏山县| 高邑县| 抚松县| 新宁县| 栾川县| 政和县| 洪泽县| 曲沃县| 衢州市| 和顺县| 贡山| 色达县| 资溪县| 贵南县| 威远县| 寿光市| 洮南市| 东阳市| 新民市| 福州市| 罗平县|