QT里使用sqlite的问题,好多坑

  1. 我使用sqlite,开发机上好好的,测试机上却不行。后来发现是缺少驱动(Driver not loaded Driver not loaded),代码检查了又检查,发现应该是缺少dll文件(系统不提示,是自己使用 QMessageBox::warning(NULL, ("error"), database.lastError().text());后猜到的)。于是自己千方百计的想办法,反复测试,就是不行。结果悲剧的发现,原来是多次设置路径错误,浪费一上午时间。应该直接在可执行exe文件的同一目录下设置目录和文件如下即可:

my.exe\sqldrivers\qsqlite4.dll

既不要写成:

my.exe\plugins\sqldrivers\qsqlite4.dll

也不要写成

my.exe\sqldrivers\sqlite\qsqlite4.dll (因为QT自己的目录就是C:\Qt\4.8.6_2008\src\plugins\sqldrivers\sqlite)

另外,放在my.exe同一目录下也没有用。

  1. 编程的时候,注意不能使用new QSqlDatabase();后调用addDatabase()函数。原因是什么我也不知道,反正结论在这里:

http://qt-project.org/doc/qt-4.8/qsqldatabase.html#open

  1. 编程的时候注意,要填上QSQLITE,不是SQLITE

QSqlDatabase database = QSqlDatabase::addDatabase("QSQLITE");

  1. 使用QSqlDatabase::addDatabase函数的时候,如果是一个临时对象,那么要把它命名一下,比如(关键是第二个参数):

QSqlDatabase localdb = QSqlDatabase::addDatabase("QSQLITE", "Old_DB");

如果不写这第二个参数,那么就会把这个新连接当作默认连接,这样申请QSqlQuery对象但不写明数据库连接的话就会出错。

  1. 使用 QSqlDatabase::removeDatabase的时候,必须把前面所有语句括号括起来,莫名其妙的一种用法。不过既然是官方文档这样说,就记住它,遵守它,相关链接在这里:

http://qt-project.org/doc/qt-4.8/qsqldatabase.html#removeDatabase

  1. 还有一个文件qsqlited4.dll,不知道是干什么。

  2. 可以很方便的使用VS编译C:\Qt\4.8.6_2008\src\plugins\sqldrivers\sqlite路径下的sqlite.pro工程文件,Release编译后得到一个dll,放在相关的路径里使用没有问题。

  3. Process Explorer这个软件可以清楚地显示,当前开发exe文件依赖哪些DLL,很有帮助。这样就不用动脑筋了,观察结果即可。比如它我对这个项目提示依赖:

C:\Qt\4.8.6_2008\plugins\sqldrivers\qsqlite4.dll

但是注意,它提示的是开发机上的dll路径,客户机上的路径不一定是这样的。

但它的提示也只能作为一种参考,不能完全当真,它还提示我使用:

C:\Qt\4.8.6_2008\plugins\imageformats\qtiff4.dll

可是我根本就没有使用tiff文件。所以这个提示作为一种参考,找到自己需要的信息即可。

总结,QT发布版的坑真是多,怪不得QT公司不让免费用户静态编译和修改,大概是只让高手们用它来玩的。不知道静态编译是否可以避免这些问题。


几个有用连接:

http://qt-project.org/doc/qt-4.8/sql-driver.html

http://blog.sina.com.cn/s/blog_a6fb6cc90101gx30.html

http://blog.csdn.net/hustyangju/article/details/17799189

http://blog.chinaunix.net/uid-28394603-id-3775493.html (讨论回滚)

安装MySQL驱动:

http://blog.sina.com.cn/s/blog_74a7e56e01017s64.html

插件工作机制:

http://blog.csdn.net/dbzhang800/article/details/6543489

http://blog.csdn.net/csfreebird/article/details/17793161

SQLite学习手册

http://my.oschina.net/eechen/blog/84641

http://my.oschina.net/eechen/blog/84639

http://www.oschina.net/question/12_53183 (一个小时内学习 SQLite 数据库

相关推荐
刺客xs6 小时前
Qt ----- QT线程
开发语言·qt
SunkingYang9 小时前
QT程序如何将事件和消息发送给MFC程序,MFC程序如何接收消息和事件
qt·mfc·消息·事件·通信·通讯·传递
凯子坚持 c11 小时前
Qt 5.14.0 入门框架开发全流程深度解析
开发语言·qt
深蓝海拓11 小时前
PySide6从0开始学习的笔记(十四)创建一个简单的实用UI项目
开发语言·笔记·python·qt·学习·ui·pyqt
小尧嵌入式11 小时前
Linux网络介绍网络编程和数据库
linux·运维·服务器·网络·数据库·qt·php
海涛高软12 小时前
Qt中使用QListWidget列表
开发语言·qt
010米粉01012 小时前
Qt之构建方式
qt
凯子坚持 c13 小时前
Qt 信号与槽机制深度解析
开发语言·qt
世转神风-13 小时前
qt-初步编译运行报错-When executing step “Make“-无法启动进程“make“
开发语言·qt
一然明月1 天前
QT之基础控件
开发语言·qt