今天用sqlite3访问中文路径的数据库文件,发现sqlite3_open函数返回失败,问度娘后,有网友建议sqlite3_open16打开,sqlite3_open16和sqlite3_open区别如下:
sqlite3_open16()的filename参数是UTF-16编码。
sqlite3_open()的filename参数时UTF-8编码。
换成sqlite3_open16()后,确实能打开,但后续的sqlite3_prepare_v2函数返回SQLITE_ERROR错误,找了很多方法都不行。最后从《sqlite中文路径非常规解决方案》找到一个很不错的方法,即把主程序所在目录设置为当前目录,sqlite的数据库文件以主程序所在目录的相对路径访问。一般的库,如:MFC、qt都有类似的方法,如qt的QDir::setCurrent函数,如下:
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
// 设置当前目录为主程序exe所在目录,其中CHelper::getModuleDir()返回主程序exe目录
QDir::setCurrent(CHelper::getModuleDir());
..... // 其它代码
}
访问slite数据的代码如下:
bool CSqliteDB::openDB()
{
int result = sqlite3_open("./database/HyDraPressTrainStudy.s3db", &m_pDb);
if (result == SQLITE_OK)
{
m_bIsOpen = true;
return true;
}
m_bIsOpen = false;
return false;
}
sqlite3的db文件存放路径为:D:\work\SoftwareAbout\我的项目\HyDraPressTrainStudy\x64\Debug\database\HyDraPressTrainStudy.s3db
而主程序exe所在目录路径为:D:\work\SoftwareAbout\我的项目\HyDraPressTrainStudy\x64\Debug,这也就是上面的CHelper::getModuleDir()返回的目录路径。
通过设置当前目录为D:\work\SoftwareAbout\我的项目\HyDraPressTrainStudy\x64\Debug,再通过在openDB()中相对路径访问就可以成功了,当然相对路径中不能再包含中文,否则依然不会成功。
直接如下访问会失败:
sqlite3_open("D:\\work\\SoftwareAbout\\我的项目\\HyDraPressTrainStudy\\x64\\Debug\\database\\HyDraPressTrainStudy.s3db", &m_pDb);
另外如下方法也可以:
本文介绍了一种解决SQLite无法打开中文路径下数据库文件的问题的方法。通过将程序运行目录设置为主程序所在目录,并使用相对路径访问数据库,成功解决了该问题。
2982

被折叠的 条评论
为什么被折叠?



