昨天在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);
}