sqlite3_prepare_v2返回26错误码的解决

sqlite3_prepare_v2返回26错误码的解决,第1张

概述问题描述: C++写了一个SQLite小工具32位的,在64位win7下执行出错 处理过程: 1 来Debug,我有源码我怕谁 经过跟踪定位到sqlite3_prepare_v2()函数,返回错误码为26. 通过查找26的定义为:#define SQLITE_NOTADB      26   /* File opened that is not a database file */ 就是说没有识别

问题描述:

C++写了一个sqlite小工具32位的,在64位win7下执行出错


处理过程:


1 来DeBUG,我有源码我怕谁

经过跟踪定位到sqlite3_prepare_v2()函数,返回错误码为26.

通过查找26的定义为:#define sqlITE_NOTADB 26/* file opened that is not a database file */

就是说没有识别db文件。


2 检查db文件

通过常用的sqlite工具测试,该db文件是完好的,能打开查数据。


3 这时,想到了可能是程序使用的sqlite3.dll库版本不对,

这种情况在使用一些第三方库时经常出现,如用c++写MysqL应用程序用到了 cppconn,需要区分32位64位,还要区分deBUG,release,还要区分vs版本

所以发布程序稍有不慎就踩坑。

经检查发现程序目录中根本就没有sqlite3.dll,所以程序肯定是加载了系统目录下的dll,

通过进程查看工具发现加载了win7系统目录下的库:windows\syswow64\sqlite3.dll

于是找了一份32位的库文件sqlite3.dll放到程序目录,再执行OK了。


问题解决了,但还有个问题搞不懂,我的32位程序怎么能够加载64位sqlite3.dll并且不会在启动时报错!?

总结

以上是内存溢出为你收集整理的sqlite3_prepare_v2返回26错误码的解决全部内容,希望文章能够帮你解决sqlite3_prepare_v2返回26错误码的解决所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1162534.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存