毕业论文开发语言企业开发JAVA技术.NET技术WEB开发Linux/Unix数据库技术Windows平台移动平台嵌入式论文范文英语论文
您现在的位置: 毕业论文 >> 嵌入式 >> 正文

错误显示“sqlite3_open”: 不能将参数 1 从“TCHAR”转换为“const char *”

更新时间:2012-10-12:  来源:毕业论文

我在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下编译才才会导出

设为首页 | 联系站长 | 友情链接 | 网站地图 |

copyright©lwfree.com 六维论文网 严禁转载
如果本毕业论文网损害了您的利益或者侵犯了您的权利,请及时联系,我们一定会及时改正。