码迷,mamicode.com
首页 > 数据库 > 详细

sqlite学习笔记之sqlite3_open函数的使用

时间:2017-06-10 18:13:18      阅读:306      评论:0      收藏:0      [点我收藏+]

标签:targe   连接数据库   har   数据库文件   article   rect   isa   include   中文   

作者:朱金灿

来源: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   中文   

原文地址:http://www.cnblogs.com/jzdwajue/p/6979313.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!