我在vs2008上建个了wince的智能设备,在使用sqlite的时候出现字符转换问题。
bool MySQLite::sqlite_connect( TCHAR filename)
{
db=NULL;
zErrMsg = 0;
row = 0, column = 0;
int rc;
rc = sqlite3_open( filename, &db); //打开指定的数据库文件,如果不存在将创建一个同名的数据库文件
if( rc )
{
wcscpy(zErrMsg,_T("sqlite3_errmsg(db)"));//保存错误信息
sqlite3_close(db);
return false;
}
return TRUE;
}
而调用sqlite3_open这个函数时,单片机温度自动控制系统设计跳到头文件
int sqlite3_open(
const char *filename, /* Database filename (UTF-8) */
sqlite3 **ppDb /* OUT: SQLite db handle */
);
这里出现字符不匹配,错误显示“sqlite3_open”: 不能将参数 1 从“TCHAR”转换为“const char *”
强制类型转换一下,看看会出什么提示…
把 rc = sqlite3_open( filename, &db); //打开指定的数据库文件,如果不存在将创建一个同名的数据库文件 变成下面的:
#if defined(UNICODE) || defined(_UNICODE)
rc = sqlite3_open16( filename, &db);
#else
rc = sqlite3_open( filename, &db);
#endif
你的数据库名字怎么能用一个tchar表示呢?
怎么也要一串字符串,搞清楚参数吧
你的lib文件时自己编译的吗,我比较怀疑你的lib文件时在ANSI环境下编译的,所以你找不到sqlite3_open16这个函数,因为这个函数是要在UNICODE下编译才才会导出