SQLite3学习与Wince下文件绝对路径

前端之家收集整理的这篇文章主要介绍了SQLite3学习与Wince下文件绝对路径前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
昨天在wince6.0下编译sqlite3.7.14生成了dll和lib,并拷贝到wince设备相应的目录下进行测试。

(如果编译3.7.14库文件的话参考:http://blog.csdn.net/feihu521a/article/details/8129612

今天测试的时候总提示:no such table.....,google一下才明白,因为sqlite打开文件时没有的话会自己创建一个同名文件,而新建的当然没有table了。这个是由于wince下没有相对路径只有绝对路劲引起的,也就是没有哦找到对应的.db文件。WinCE提供了GetModuleFileName系统API来获取可执行程序的完整路径与文件名。

函数原型:

DWORD GetModuleFileName(
                        HMODULE hModule,// 将要得到的模块的句柄。如果是当前模块,NULL
                        LPTSTR lpFilename,// 得到的文件名
                        DWORD nSize       //  一般MAX_PATH就可以了
                        );

经过测试://获取当前文件绝对路径
void GetCurrentDirectory(CString &strPath) 
{ 
 wchar_t pBuf[256]; 
 GetModuleFileName(NULL,pBuf,MAX_PATH); 
 strPath=pBuf; 
 strPath = strPath.Left(strPath.ReverseFind('\\') + 1); 
}
原文链接:https://www.f2er.com/sqlite/201659.html

猜你在找的Sqlite相关文章