Qt之操作数据库(SQLite)实例

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工具打开,显示结果如下:

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值