linux下QT4自带的sqlite驱动不可用该怎么解决
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux下QT4自带的sqlite驱动不可用该怎么解决相关的知识,希望对你有一定的参考价值。
我告诉你个方法,绝对管用,你这种情况是没有安装mysql的驱动,提示只有sqlite的驱动。在命令行下安装libqt4-sql-mysql(sudoapt-getinstalllibqt4-sql-mysql),然后将/usr/lib/qt4/plugins/sqldrivers/libqsqlmysql.so拷贝到你的QtSDKsqldrivers目录下,我的是在/QtSDK/Desktop/Qt/481/gcc/plugins/sqldrivers,里面同时还有qsqlite.so,所以刚才会说只能找到qsqlite 参考技术A -、安装MySQLQt
mysql-5.5.13-win32载址:
mysql安装程:
安装mysql我需要includelib文件夹即
二、编译mysql驱
打qt目录D:\Qt\4.8.5\plugins\sqldrivers面包含qt支持数据库驱包括sqliteodbc两种默认支持mysql支持mysql我进入D:\Qt\4.8.5\src\plugins\sqldrivers\mysql目录编译mysql.pro编译步骤:
第、通始菜单打Qt 4.8.5 Command Prompt环境其结:
第二、修改mysql.pro文件第二行添加内容(路径能空格)
INCLUDEPATH += "D:\mysql\include"
LIBS+= "D:\mysql\lib\libmysql.lib"
进入mysql.pro工程目录再配置
cd D:\Qt\4.8.5\src\plugins\sqldrivers\mysql
qmake mysql.pro本回答被提问者采纳
Qt之操作数据库(SQLite)实例
QtSql模块提供了与平台以及数据库种类无关的访问SQL数据库的接口,这个接口由利用Qt的模型视图结构将数据库与用户界面集成的一套类来支持。
QSqlDatabase对象象征了数据库的关联。Qt使用驱动程序与各种数据库的应用编程接口进行通信。Qt的桌面版(Desktop Edition)包括如下一些驱动程序:
驱动程序 数据库
QDB2 IBM DB2 7.1版以及更新的版本
QIBASE Borland InterBase
QMYSQL MySql
QOCI 甲骨文公司(Oracle Call Interface)
QODBC ODBC(包括微软公司的QSL服务)
QPSQL PostgreSQL的7.3版以及更高版本
QSQLITE QSLite第3版
QSQLITE2 QSLite第2版
QTDS Qybase自适应服务器
访问QSqlite数据库的实例:
步骤:
1、创建Qt控制台程序。
2、在pro问价中添加QT +=sql;
3、在main.cpp中添加如下代码
#include <QCoreApplication> #include <QSql> #include <QSqlDatabase> #include <QSqlError> #include <QSqlQuery> #include <QString> #include <QFile> #include <QDebug> #include <QVariantList> int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); QSqlDatabase database = QSqlDatabase::addDatabase("QSQLITE"); database.setDatabaseName("CashSystem.db"); if(database.open()) { qDebug()<<"Database Opened"; QSqlQuery sql_query; QString create_sql = "create table member (id int primary key, name varchar(30), address varchar(30))"; //创建数据表 QString insert_sql = "insert into member values(?,?,?)"; //插入数据 QString select_all_sql = "select * from member"; sql_query.prepare(create_sql); //创建表 if(!sql_query.exec()) //查看创建表是否成功 { qDebug()<<QObject::tr("Table Create failed"); qDebug()<<sql_query.lastError(); } else { qDebug()<< "Table Created" ; //插入数据 sql_query.prepare(insert_sql); QVariantList GroupIDs; GroupIDs.append(0); GroupIDs.append(1); GroupIDs.append(2); QVariantList GroupNames; GroupNames.append("hsp"); GroupNames.append("rl"); GroupNames.append("spl"); QVariantList GroupAddress; GroupAddress.append("南充"); GroupAddress.append("宝鸡"); GroupAddress.append("南充"); sql_query.addBindValue(GroupIDs); sql_query.addBindValue(GroupNames); sql_query.addBindValue(GroupAddress); if(!sql_query.execBatch()) { qDebug()<<sql_query.lastError(); } else { qDebug()<<"插入记录成功"; } //查询所有记录 sql_query.prepare(select_all_sql); if(!sql_query.exec()) { qDebug()<<sql_query.lastError(); } else { while(sql_query.next()) { int id = sql_query.value(0).toInt(); QString name = sql_query.value(1).toString(); QString address = sql_query.value(2).toString(); qDebug()<<QString("ID:%1 Name:%2 Address:%3").arg(id).arg(name).arg(address); } } } } database.close(); // QFile::remove("CashSystem.db"); return a.exec(); }
4、运行截图:
5、在项目的debug文件夹下,生成了对应的.db文件,使用navicat forSqlite工具打开,显示结果如下:
参考链接:
以上是关于linux下QT4自带的sqlite驱动不可用该怎么解决的主要内容,如果未能解决你的问题,请参考以下文章
visual studio 2010可用的sqlite驱动程序(实体数据模型使用)