QtSql模块提供了与平台以及数据库种类无关的访问SQL数据库的接口,这个接口由利用Qt的模型视图结构将数据库与用户界面集成的一套类来支持。
如未安装sqlite驱动,可查看链接安装:https://blog.csdn.net/qq_16093323/article/details/88226397
查看sqlite数据库中数据软件链接:https://download.csdn.net/download/qq_16093323/10997463(内含有破解软件)
QSqlDatabase对象象征了数据库的关联。Qt使用驱动程序与各种数据库的应用编程接口进行通信。Qt的桌面版(Desktop Edition)包括如下一些驱动程序:
访问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("LineData.db");
if(database.open())
{
qDebug()<<"Database Opened";
QSqlQuery sql_query;
QString create_sql = "create table Data (ID int primary key, LeftX text, LeftY text, RightX text, RightY text, Extends text)"; //创建数据表
QString insert_sql = "insert into Data values(?,?,?,?,?,?)"; //插入数据
QString select_all_sql = "select * from Data";
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 GroupLeftXs;
GroupLeftXs.append("-2");
GroupLeftXs.append("-2");
GroupLeftXs.append("-2");
QVariantList GroupLeftYs;
GroupLeftYs.append("100");
GroupLeftYs.append("100");
GroupLeftYs.append("100");
QVariantList GroupRightXs;
GroupRightXs.append("-2");
GroupRightXs.append("-2");
GroupRightXs.append("-2");
QVariantList GroupRightYs;
GroupRightYs.append("100");
GroupRightYs.append("100");
GroupRightYs.append("100");
QVariantList GroupExtends;
GroupExtends.append("100");
GroupExtends.append("100");
GroupExtends.append("100");
sql_query.addBindValue(GroupIDs);
sql_query.addBindValue(GroupLeftXs);
sql_query.addBindValue(GroupLeftYs);
sql_query.addBindValue(GroupRightXs);
sql_query.addBindValue(GroupRightYs);
sql_query.addBindValue(GroupExtends);
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 LeftX = sql_query.value(1).toString();
QString LeftY = sql_query.value(2).toString();
QString RightX = sql_query.value(1).toString();
QString RightY = sql_query.value(2).toString();
QString Extends = sql_query.value(1).toString();
qDebug()<<QString("ID:%1 LeftX:%2 LeftY:%3 RightX:%4 RightY:%5 Extends:%6").arg(id).arg(LeftX).arg(LeftY).arg(RightX).arg(RightY).arg(Extends);
}
}
}
}
database.close();
//QFile::remove("LineData.db");
return a.exec();
}
4、运行截图:
5、在项目的debug文件夹下,生成了对应的.db文件,使用navicat premium工具打开,显示结果如下: