Qt中使用数据库

关于qt构建项目后需要返回上一级目录寻找debug

我们可以在项目设置中

点击项目

不要勾选即可

qt中设置成员变量怎么为其添加函数快捷键

答案:alt + enter

qt中使用数据库

1 在pro 文件中加入

QT += core gui sql

需要用到的头文件

#include <QSqlQuery> //与数据库打交道使用该头文件

#include <QSqlDatabase>

1第一步:第一步添加数据库 记住加上前缀Q 如果是mysql 就是 QMYSQL 记住大写

QSqlDatabase qsql = QSqlDatabase::addDatabase("QSQLITE");

2 ./ 在当前目录下 创建数据库 并命名

qsql.setDatabaseName("./stuinfo.db");

第三步判断是否打开

复制代码
if(!qsql.open())
    {
        QMessageBox::critical(NULL,"打开失败","ss");
    }

第四步开始 创建表 此时就要用到打交道的类了

创建表

使用完毕后记得关闭数据库

复制代码
QSqlQuery que;
    QString sql = QString("create table if  not exists tb_stuInfo(id int primary key not null,"
                          "name varchar (50),"
                          "sex varchar(2),"
                          "phone varhcar(11),"
                          "cet4 int,"
                          "gpa  real,"
                          "overllscore real);");

    if(!que.exec(sql))//判断执行是否成功
    {
        QMessageBox::critical(NULL,"wrong","执行错误");
        qDebug()<<que.lastQuery();
        return ;
    }
    qsql.close();//使用完后记得关闭数据库

QSqlQuery::next() 是 Qt 中 QSqlQuery 类的一个成员函数,用于在查询结果集中移动到下一行。当你执行了一个 SQL 查询并获取到了结果集后,你可以使用 next() 函数逐行遍历结果集。

QSqlQuery::next() 的作用:
移动游标:next() 函数会将内部的游标移动到结果集中的下一行。
返回值:如果成功移动到下一行,则返回 true;如果没有更多的行可移动,则返回 false。

QSqlQuery qu;
int id = qu.value("id").toInt();
        QString name = qu.value("name").toString();
        QString sex = qu.value("set").toString();
        QString phone  = qu.value("phone").toString();

qu 是一个 QSqlQuery 对象,
它代表了一个数据库查询的结果集。
这段代码的目的是从当前查询结果集中的当前行中获取名为 "cet4" 的列的值,
并将其转换为整数类型。*/

其他的一样  获取数据库set的值 将其值转换为string类型
相关推荐
大飞记Python11 分钟前
【2026更新】Python基础学习指南(AI版)——04数据类型
开发语言·人工智能·python
Alice-YUE1 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
云泽8081 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
froginwe111 小时前
DOM 加载函数
开发语言
Hello eveybody1 小时前
介绍一下背包DP(Python)
开发语言·python·动态规划·dp·背包dp
AI进化营-智能译站2 小时前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
iCxhust2 小时前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
Morwit2 小时前
QML组件之间的通信方案(暴露子组件)
c++·qt·职场和发展
莎士比亚的文学花园2 小时前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
图码2 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻