时间:2021-07-01 10:21:17 帮助过:22人阅读
来源:http://blog.csdn.net/clever101
打开sqlite数据库须要用到sqlite3_open函数,可是sqlite3_open函数的第一个參数是数据库文件的绝对路径。
它是有讲究的,必须是utf8字符串。也就是说假如文件路径是非utf8字符,就得转为utf字符。于是參考网上的资料。写了一个最经常使用的从多字节转utf8的函数,代码例如以下:
// 编译环境:VS 2008+sp1,Win7, project设置为多字节字符集
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, project设置为多字节字符集
#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函数的使用
标签:targe 连接数据库 har 数据库文件 article rect isa include 中文