Qt中的数据库

一. 创建数据库类:QSqlIDatabase类

1.定义数据库是使用什么样的数据库,默认支持:SQLITE,与MYSQL使用静志函数:addDatabase("XXX")

2.创建并打开数据库文件: setDatabase("指定一个数据库文件的路径")

3.open()打开数据库文件

二. 操作数据库类:QSqlQuery类

1.执行解析Sql命令,并相应执行数据库操作:.exec("具体sql命令的字符")

2.预执行.perpare("可变参数格式符的Sql命令字符串")

三. 保存数据库库数据行数据类:QRecord类

  1. 在QSqulQueny执行相关的操作后,数据库中的数据所保存的为一行行的数据的类型

  2. 有value()相关操作。可作为读取数据使用。

四. 获取数据库错误类:QSqlError

OSglQuery执行操作如果出错,可以使用QSalQuery对象调用.IastErrQr会返回一个此类的错误对象;使用datatbaseText()打印出出错信息

#include <QSqlDatabase>
#include <QSqlQuery>
#include <QSqlRecord>
#include <QSqlError>
#include <QtDebug>
#include <QFile>

int showInfo(QSqlQuery& query)
{
    QString sql = "select * from WeaponsTable";
    if(!query.exec(sql))
    {
        query.lastError().databaseText();
        return -1;
    }
    while(query.next())
    {
        int id = query.record().value(0).toInt();
        QString type = query.record().value(1).toString();
        QString version = query.record().value(2).toString();
        QString country = query.record().value(3).toString();
        qDebug() << QString("[%1] [%2] [%3] [%4]").arg(id).arg(type).arg(version).arg(country);

    }
}

int main(int argc, char *argv[])
{
    QSqlDatabase my_db = QSqlDatabase::addDatabase("QSQLITE");
    my_db.setDatabaseName("gaowanxi.db");
    if(!my_db.open())
    {
        qDebug() << my_db.lastError().databaseText();
        return -1;
    }
    QString sql = "create table if not exists WeaponsTable(序号 int primary key,类别 text,型号 text,产地 text)";
    QSqlQuery query(my_db);
    if(!query.exec(sql))
    {
        query.lastError().databaseText();
        return -1;
    }
    sql = "insert into WeaponsTable values(8,'自动步枪','M4','德国')";
    if(!query.exec(sql))
    {
        query.lastError().databaseText();
        return -1;
    }


    //数据库的名字;WeaponsTable
//    sql = "insert into WeaponsTable value(?,?,?,?)";
//    query.prepare(sql);
//    QByteArray cache;
//    QFile file(":/WeaponsTable.txt");
//    if(!file.open(QIODevice::ReadOnly))
//    {
//        qDebug()<<"读取文件失败";
//        return -1;
//    }
//    QString lineData;
//    while(!file.atEnd())
//    {
//        cache = file.readLine();
//        lineData =  QString(cache).trimmed();
//        bool empty = lineData.isEmpty();
//        if(empty)
//        {
//             continue;
//        }
//        QStringList strlist = lineData.split(',');
//        //这个就是stringlist的分割方法
//        query.bindValue(0,strlist[0]);
//        query.bindValue(1,strlist[1]);
//        query.bindValue(2,strlist[2]);
//        query.bindValue(3,strlist[3]);
//        if(!query.exec())
//        {
//            qDebug() << query.lastError().databaseText();
//            return -1;
//        }
//    }

    showInfo(query);
    return 0;
}
相关推荐
难以触及的高度18 分钟前
mysql中between and怎么用
数据库·mysql
Jacky(易小天)32 分钟前
MongoDB比较查询操作符中英对照表及实例详解
数据库·mongodb·typescript·比较操作符
Karoku0661 小时前
【企业级分布式系统】ELK优化
运维·服务器·数据库·elk·elasticsearch
小技与小术2 小时前
数据库表设计范式
数据库·mysql
安迁岚2 小时前
【SQL Server】华中农业大学空间数据库实验报告 实验三 数据操作
运维·服务器·数据库·sql·mysql
安迁岚2 小时前
【SQL Server】华中农业大学空间数据库实验报告 实验九 触发器
数据库·sql·mysql·oracle·实验报告
Loganer2 小时前
MongoDB分片集群搭建
数据库·mongodb
LKID体3 小时前
Python操作neo4j库py2neo使用之创建和查询(二)
数据库·python·neo4j
刘大浪3 小时前
后端数据增删改查基于Springboot+mybatis mysql 时间根据当时时间自动填充,数据库连接查询不一致,mysql数据库连接不好用
数据库·spring boot·mybatis
一只爱撸猫的程序猿3 小时前
简单实现一个系统升级过程中的数据平滑迁移的场景实例
数据库·spring boot·程序员