sqlite學習筆記之sqlite3_open函數的使用

來源:互聯網
上載者:User

標籤:

朱金燦

來源:http://blog.csdn.net/clever101

 

       開啟sqlite資料庫需要用到sqlite3_open函數,但是sqlite3_open函數的第一個參數是資料庫檔案的絕對路徑。它是有講究的,必須是utf8字串。也就是說假如檔案路徑是非utf8字元,就得轉為utf字元。於是參考網上的資料,寫了一個最常用的從多位元組轉utf8的函數,代碼如下:

// 編譯環境:VS 2008+sp1,Win7, 工程設定為多位元組字元集std::string MbcsToUtf8( const char* pszMbcs ){std::string str;WCHAR   *pwchar=0;CHAR    *pchar=0;int len=0;int codepage = AreFileApisANSI() ? CP_ACP : CP_OEMCP;len=MultiByteToWideChar(codepage, 0, pszMbcs, -1, NULL,0);pwchar=new WCHAR[len];if(pwchar!=0){len = MultiByteToWideChar(codepage, 0, pszMbcs, -1, pwchar, len);if( len!=0 ){len = WideCharToMultiByte(CP_UTF8, 0, pwchar, -1, 0, 0, 0, 0);pchar=new CHAR[len];if(pchar!=0){len = WideCharToMultiByte(CP_UTF8, 0, pwchar, -1, pchar, len,0, 0);if(len!=0)                {str = pchar;                   }delete pchar;}delete pwchar;}}return str;}

測試代碼如下:

// 編譯環境:VS 2008+sp1,Win7, 工程設定為多位元組字元集#include <sqlite3.h>#include <string>int main(void){sqlite3* db = 0;char* pszErrMsg = NULL;// 串連資料庫    std::string strImgIndexFileName = “C:\\test.db”std::string strUtf8File = MbcsToUtf8(strImgIndexFileName.c_str());int ret = sqlite3_open(strUtf8File.c_str(),&db);if ( ret != SQLITE_OK ){fprintf(stderr, "無法開啟資料庫: %s", sqlite3_errmsg(db));return 1;}  return 0;}

參考文獻:

1. sqlite3問題2:中文路徑的支援

sqlite學習筆記之sqlite3_open函數的使用

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.