如何在 静态编译的QT 5.5.1 中 使用数据库插件连接 ODBC(调用静态插件)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了如何在 静态编译的QT 5.5.1 中 使用数据库插件连接 ODBC(调用静态插件),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3328字,纯文字阅读大概需要5分钟。
内容图文
说做就做,按着官方网站的说明,无脑照搬步骤编译出来了静态
版本,但是在使用的时候出问题了:
运行的时候提示:
"Driver not loaded Driver not loaded"
Available drivers:
"QSQLITE"
擦,原来默认没把odbc的驱动编译进去,好吧,按照Qt帮助文档的说明编译出了 libqsqlodbcd.a 、libqsqlodbc.a
这两个文件,然后想当然地把这两个文件放到 %QT/plugins的sqldrivers文件夹下,你猜怎么着,根本就没有这个文件夹!
好吧,既然没有,那我就给你建立一个,但还是没什么鬼用……
终于,皇天不负有心人,我了解到,我现在使用ODBC驱动的方式 叫做“调用静态插件”, Qt正好有那么篇介绍的文章:
How to Create Qt Plugins
按照上面的说明,在.pro 文件中加入如下语句:
QTPLUGIN+= qsqlodbc
并在.cpp文件中添加语句:
#include<QtPlugin>
Q_IMPORT_PLUGIN(QODBCDriverPlugin) 这里要说一下,插件的名字,也就是这里的“QODBCDriverPlugin”,去哪里找呢?这得到我们编译这个驱动的.pro文件中找,这里是 odbc.pro, (目录: %Qt\src\qt-everywhere-opensource-src-5.5.1\qtbase\src\plugins\sqldrivers\odbc)。 另外,还要把和 .a库一起编译出来的两个 .prl 文件放到 %Qt\lib 目录下,并编辑这两个文件,把里面 QMAKE_PRL_LIBS 中的静态库路径修改成你编译出来的静态库的路径。 做完以上的,就执行一次 clean ,qmake 重新编译就OK了,这时候是不是能连接上了啊,哈哈……(这过程的心酸,终于换来了收获的喜悦……啊啊啊) 下面附上测试的 Demo 代码 staticTest.pro[cpp] view plain copy
- #-------------------------------------------------
- #
- # Project created by QtCreator 2016-01-16T20:55:32
- #
- #-------------------------------------------------
- QT += core gui sql
- greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
- QTPLUGIN += qsqlodbc
- TEMPLATE = app
- SOURCES += main.cpp\
- mainwindow.cpp
- HEADERS += mainwindow.h
- FORMS += mainwindow.ui
[cpp] view plain copy
---------------------------------------------------
mainwindow.cpp
- #include "mainwindow.h"
- #include "ui_mainwindow.h"
- #include <QDebug>
- #include <QtSql/QSqlDatabase>
- #include <QtSql/QSqlError>
- #include <QtSql/QSqlDriver>
- #include <QtPlugin>
- Q_IMPORT_PLUGIN(QODBCDriverPlugin)
- MainWindow::MainWindow(QWidget *parent) :
- QMainWindow(parent),
- ui(new Ui::MainWindow)
- {
- ui->setupUi(this);
- }
- MainWindow::~MainWindow()
- {
- delete ui;
- }
- void MainWindow::on_pushButton_clicked()
- {
- qDebug()<<"haha";
- QSqlDatabase qDB = QSqlDatabase::addDatabase("QODBC");
- qDB.setHostName("127.0.0.1");
- qDB.setDatabaseName("Driver={sql server};server=127.0.0.1;database=MyTempDB;");
- qDB.setUserName("sa");
- qDB.setPassword("123456");
- bool IsOpen = qDB.open();
- if(IsOpen)
- {
- qDebug()<<"connect to Database Success.";
- }
- else
- {
- qDebug()<<"Connect failed!";
- QSqlError qerror = qDB.lastError();
- qDebug()<<qerror.text();
- }
- qDebug() << "Available drivers:";
- QStringList drivers = QSqlDatabase::drivers();
- foreach(QString driver, drivers)
- qDebug() << "\t" << driver;
- }
*/
*--------------------------------------
** Edit by : 小菜
** Time: 2016-01-19
*--------------------------------------
*/
http://blog.csdn.net/humadivinity/article/details/50545100
如何在 静态编译的QT 5.5.1 中 使用数据库插件连接 ODBC(调用静态插件)
标签:
本文系统来源:http://www.cnblogs.com/findumars/p/5621297.html
内容总结
以上是互联网集市为您收集整理的如何在 静态编译的QT 5.5.1 中 使用数据库插件连接 ODBC(调用静态插件)全部内容,希望文章能够帮你解决如何在 静态编译的QT 5.5.1 中 使用数据库插件连接 ODBC(调用静态插件)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。