QT--SQLite

配置类相关的表,所以我使用sqlite,且QT自带该组件;

1.安装 sqlite-tools-win-x64-3460000、SQLiteExpert5.4.31.575
使用SQLiteExpert建好数据库.db文件,和对应的表后把db文件放在指定目录 ./db/program.db;

2.选择sql组件

在这里插入图片描述
3.新增数据库处理类,在使用数据库的地方调用类成员函数即可

DataModel::DataModel()
{
	db = QSqlDatabase::addDatabase("QSQLITE", "");
	db.setDatabaseName("./db/program.db");
    connectDataBase();
}

DataModel::~DataModel()
{
    disconnectDataBase();
}

// 打开数据库文件
bool DataModel::connectDataBase() {
    bool ret = db.open();
    if (!ret) {
        outPutMsg(QtDebugMsg, "DataModel::connectDataBase error = " + db.lastError().text());
    } 
    return ret;
}
// 关闭数据库文件
void DataModel::disconnectDataBase() {
    db.close();
}
QStringList DataModel::queryProgramList() {
    QStringList programList;
    // 根据名字查询
    QString sql = QString("select sectionBarName,programNo from program where 1=1;");
    outPutMsg(QtDebugMsg, "DataModel::queryProgramList sql = " + sql);
    // 创建一个可以对db执行语句的对象
    QSqlQuery query(db);
    // 执行sql语句
    bool ret = query.exec(sql);
    if (!ret)
    {
        outPutMsg(QtDebugMsg, "DataModel::queryProgramNo error = " + query.lastError().text());
        return programList;
    }

    // 行坐标向下移
    while (query.next())
    {
        //获取数据库query所指的那行的数据
        QString program;
        program += (query.value(0).toString() + ";"); // sectionBarName
        program += QString::number(query.value(1).toInt()); // programNo

       // outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode programInfo = " + program);
        programList.append(program);
    }
    return programList;
}
// 根据型材代号查询程序号码
QString DataModel::queryProgramNo(QString sectionBarNo) {
    // 根据名字查询
    QString sql = QString("select programNo from program where sectionBarName=\'%1\';").arg(sectionBarNo);
    //QString sql = QString("select programNo from program where 1=1");
    outPutMsg(QtDebugMsg, "DataModel::queryProgramNo sql = " + sql);
    // 创建一个可以对db执行语句的对象
    QSqlQuery query(db);
    // 执行sql语句
    bool ret = query.exec(sql);
    if (!ret)
    {
        outPutMsg(QtDebugMsg, "DataModel::queryProgramNo error = " + query.lastError().text());
        return "";
    }
    QString programNo = "";
    // 行坐标向下移
    while (query.next())
    {
        //获取数据库query所指的那行的数据
        programNo = QString::number(query.value(0).toInt());
        outPutMsg(QtDebugMsg, "DataModel::queryProgramNo programNo = " + programNo);
    }
    return programNo;
}

// 根据程序号码查询
QString DataModel::queryProgramByNo(QString programNo) {
    // 根据名字查询
    QString sql = QString("select sectionBarName from program where programNo=\'%1\';").arg(programNo);
    //QString sql = QString("select programNo from program where 1=1");
    outPutMsg(QtDebugMsg, "DataModel::queryProgramByNo sql = " + sql);
    // 创建一个可以对db执行语句的对象
    QSqlQuery query(db);
    // 执行sql语句
    bool ret = query.exec(sql);
    if (!ret)
    {
        outPutMsg(QtDebugMsg, "DataModel::queryProgramByNo error = " + query.lastError().text());
        return "";
    }
    QString sectionBarNo = "";
    // 行坐标向下移
    while (query.next())
    {
        //获取数据库query所指的那行的数据
        sectionBarNo = QString::number(query.value(0).toInt());
        outPutMsg(QtDebugMsg, "DataModel::queryProgramByNo sectionBarNo = " + sectionBarNo);
    }
    return sectionBarNo;
}


// 根据型材代号查询程序号码
QStringList DataModel::queryProgramInfoBySectionCode(QString sectionBarNo) {
    QStringList programInfoList;
    // 根据名字查询
    // 使用索引sectionBarName
    QString sql = QString("select stepNo, cutNo,x, y, f, Rx, Ry from programInfo where programNo = (select programNo from program where sectionBarName=\'%1\');").arg(sectionBarNo);
    //QString sql = QString("select programNo from program where 1=1");
    outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode sql = " + sql);
    // 创建一个可以对db执行语句的对象
    QSqlQuery query(db);
    // 执行sql语句
    bool ret = query.exec(sql);
    if (!ret)
    {
        outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode error = " + query.lastError().text());
        return programInfoList;
    }
    // 行坐标向下移
    while (query.next())
    {
        //获取数据库query所指的那行的数据
        QString programInfo;
         
        programInfo += (QString::number(query.value(0).toInt())+";"); // stepNo
        programInfo += (QString::number(query.value(1).toInt())+";"); // cutNo
        programInfo += (QString::number(query.value(2).toDouble(), 'f', 2) + ";"); // x
        programInfo += (QString::number(query.value(3).toDouble(), 'f', 2) + ";"); // y
        programInfo += (QString::number(query.value(4).toDouble(), 'f', 2) + ";"); // f 速度
        programInfo += (QString::number(query.value(5).toDouble(), 'f', 2) + ";"); // Rx
        programInfo += (QString::number(query.value(6).toDouble(), 'f', 2)); // Ry
        
        outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode programInfo = " + programInfo);
        programInfoList.append(programInfo);
    }
    return programInfoList;
}

// 更新程序信息
bool DataModel::updateProInfosByProNo(QString proNo, QStringList proInfoList) {
    // 开启事务
    if (!db.transaction()) {
        outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo db.error = " + db.lastError().text());
        return false;
    }

    QStringList programInfoList;
    // 根据名字查询
    // 使用索引sectionBarName
    QString sqlDel = QString("delete from programInfo where programNo=\'%1\';").arg(proNo);
    outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo sqlDel = " + sqlDel);
    // 创建一个可以对db执行语句的对象
    QSqlQuery query(db);
    // 执行sql语句
    bool ret = query.exec(sqlDel);
    if (!ret)
    {
        outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo error = " + query.lastError().text());
        return false;
    }
    try {
        for (int i = 0; i < proInfoList.size(); i++) {
            QStringList programInfo = proInfoList.at(i).split(";");
            QString sqlOne = "insert into programInfo values ( " + proNo + ",";

            for (int j = 0; j < programInfo.size(); j++) {
                if (j > 0) {
                    sqlOne += ",";
                }
                sqlOne += programInfo.at(j) ;
            }
            sqlOne += ");";
            outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo sqlOne = " + sqlOne);
            if (!query.exec(sqlOne))
            {
                outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo error = " + query.lastError().text());
                return false;
            }
        }
    }
    catch (...) {
        outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo error = " + query.lastError().text());
        return false;
    }

    
    // 开启事务
    if (!db.commit()) {
        outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo db.error = " + db.lastError().text());
        return false;
    }

    return true;
}
// 保存程序信息
void ClearCorner::on_edit_saveBtn_clicked() {
    QStringList proInfoList;
    for (int i = 0; i < modelProgram.rowCount(); i++) {
        QString strTmp;
        for (int j = 0; j < modelProgram.columnCount(); j++) {
            QStandardItem* item = modelProgram.item(i, j);
            if (j > 0) {
                strTmp += ";";
            }
            strTmp += item->text();
        }
        outPutMsg(QtDebugMsg, "ClearCorner::on_edit_saveBtn_clicked strTmp = " + strTmp);
        proInfoList.append(strTmp);
    }
    DataModel dataModel;
    bool ret = dataModel.updateProInfosByProNo(ui.edit_lineEdit_programNo->text(), proInfoList);
    if (ret) {
        QMessageBox::information(nullptr, "提示", "更新程序成功!");
    }
    else {
        QMessageBox::warning(nullptr, "提示", "更新程序失败!");
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/791584.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

GaussDB关键技术原理:高性能(五)

GaussDB关键技术原理&#xff1a;高性能&#xff08;四&#xff09;从USTORE存储引擎、计划缓存计划技术、数据分区与分区剪枝、列式存储和向量化引擎、SMP并行执行等五方面对高性能关键技术进行解读&#xff0c;本篇将从LLVM动态查询编译执行、SQL-BYPASS执行优化、线程池化、…

【文档+源码+调试讲解】冷冻仓储管理系统

摘 要 随着互联网时代的到来&#xff0c;同时计算机网络技术高速发展&#xff0c;网络管理运用也变得越来越广泛。因此&#xff0c;建立一个B/S结构的冷冻仓储管理系统&#xff0c;会使冷冻仓储管理系统工作系统化、规范化&#xff0c;也会提高冷冻仓储管理系统平台形象&#x…

若依搭建 帝可得 售货机 笔记

一、搭建项目 1.后端gitee链接&#xff1a; 启动项目时记得修改mysql和redis的相关信息&#xff1b;创建项目相关数据库&#xff0c;并导入初始化的SQL脚本 dkd-parent: 帝可得后台管理系统 (gitee.com) 2.前端gitee链接&#xff1a; 启动项目时记得安装依赖&#xff1a;np…

IPv4与IPv6的定义和主要区别

IPv4与IPv6的定义 IPv4&#xff0c;即互联网协议版本4&#xff08;InternetProtocolversion4&#xff09;&#xff0c;是互联网使用最为广泛的协议之一。它采用32位地址&#xff0c;以点分十进制表示&#xff0c;如192.168.1.1。 IPv6&#xff0c;即互联网协议版本6&#xff…

自动驾驶革命:商汤科技突破性大模型UniAD震撼登场

自动驾驶革命&#xff1a;商汤科技突破性大模型UniAD震撼登场&#xff01; 在人工智能的浪潮中&#xff0c;自动驾驶技术一直是科技巨头们竞相追逐的圣杯。而今&#xff0c;商汤科技联合上海人工智能实验室与武汉大学&#xff0c;以一篇名为"Planning-oriented Autonomou…

Shader每日一练(2)护盾

Shader "Custom/Shield" {Properties{_Size("Size", Range(0 , 10)) 1 // 控制噪声纹理缩放大小的参数_colorPow("colorPow", Float) 1 // 控制颜色强度的指数_colorMul("colorMul", Float) 1 // 控制颜色乘法因子_mainColor("…

政安晨:【Keras机器学习示例演绎】(五十四)—— 使用神经决策森林进行分类

目录 导言 数据集 设置 准备数据 定义数据集元数据 为训练和验证创建 tf_data.Dataset 对象 创建模型输入 输入特征编码 深度神经决策树 深度神经决策森林 实验 1&#xff1a;训练决策树模型 实验 2&#xff1a;训练森林模型 政安晨的个人主页&#xff1a;政安晨 欢…

【机器学习】独立成分分析(ICA):解锁信号的隐秘面纱

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 独立成分分析&#xff08;ICA&#xff09;&#xff1a;解锁信号的隐秘面纱引言I…

人工智能算法工程师(中级)课程3-sklearn机器学习之数据处理与代码详解

大家好&#xff0c;我是微学AI,今天给大家分享一下人工智能算法工程师(中级)课程3-sklearn机器学习之数据处理与代码详解。 Sklearn&#xff08;Scikit-learn&#xff09;是一个基于Python的开源机器学习库&#xff0c;它提供了简单有效的数据挖掘和数据分析工具。Sklearn包含了…

webstorm问题解决:无法识别 @

问题解决tsconfig.json 问题 本地的 vite.config.ts 已经配置 路径 但是&#xff0c;我用webstorm 上识别不了 解决 新增文件tsconfig.json&#xff0c;添加 baseUrl 和 paths 的配置&#xff0c;以告诉 TypeScript 和 WebStorm 如何解析路径别名 tsconfig.json {&quo…

无需构建工具,快速上手Vue2 + ElementUI

无需构建工具&#xff0c;快速上手Vue2 ElementUI 在前端开发的世界中&#xff0c;Vue.js以其轻量级和易用性赢得了开发者的青睐。而Element UI&#xff0c;作为一个基于Vue 2.0的桌面端组件库&#xff0c;提供了丰富的界面组件&#xff0c;使得构建美观且功能丰富的应用变得…

禁止使用存储过程

优质博文&#xff1a;IT-BLOG-CN 灵感来源 什么是存储过程 存储过程Stored Procedure是指为了完成特定功能的SQL语句集&#xff0c;经编译后存储在数据库中&#xff0c;用户可通过指定存储过程的名字并给定参数&#xff08;如果该存储过程带有参数&#xff09;来调用执行。 …

AndroidStudio2023.3版本avd manager模拟器无法创建

创建到最后一步的时候提示WARN - #com.android.sdklib.internal.avd.AvdManager - com.android.prefs.AndroidLocationsException: Can’t locate Android SDK installation directory for the AVD .ini file. 前提&#xff1a; 1.sdk路径没问题 2.安装了下图内容 那是什么原因…

Linux /etc/profile 详解

概述 Linux是一个多用户的操作系统。每个用户登录系统后&#xff0c;都会有一个专用的运行环境。通常每个用户默认的环境都是相同的&#xff0c;这个默认环境实际上就是一组环境变量的定义。用户可以对自己的运行环境进行定制&#xff0c;其方法就是修改相应的系统环境变量&…

原生小程序生成二维码并保存到本地

需求&#xff1a;我要在一个页面中生成一个二维码&#xff0c;并且这个二维码可以长按保存到本地或者发送给好友&#xff1b; 我这里是将生成的canvas二维码转换成图片&#xff0c;利用长按图片进行保存或转发 效果图&#xff1a; 第一步先下载对应的包&#xff1a; npm instal…

C语言笔记31 •单链表经典算法OJ题-3.反转链表•

反转链表 1.问题 给你单链表的头节点 head&#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 2.代码实现&#xff1a; //3.反转链表 #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <stdlib.h> #include <assert.h>typedef int …

LLM——langchain 与阿里 DashScop (通义千问大模型) 和 DashVector(向量数据库) 结合使用总结

文章目录 前言预览直接调用大模型使用 prompt template格式化输出使用上下文 RAG 增强检索 自定义 langchain AgentPromptTemplate 和 ChatPromptTemplate使用少量示例创建ChatPromptTemplate 前言 langchain 是一个面向大模型开发的框架&#xff0c;其中封装了很多核心组件&a…

设计模式之外观模式(Facade)

Facade设计模式&#xff0c;也称为外观模式&#xff0c;是一种结构型设计模式&#xff0c;它主要用于为子系统中的一组接口提供一个统一的高层接口&#xff0c;从而使得子系统更加容易使用。以下是关于Facade设计模式的详细介绍&#xff1a; 一、定义 Facade模式为多个复杂的…

期权专题12:期权保证金和期权盈亏

目录 1. 期权保证金 1.1 计算逻辑 1.2 代码复现 1.3 实际案例 2. 期权盈亏 2.1 价格走势 2.2 计算公式 2.2.1 卖出期权 2.2.2 买入期权 免责声明&#xff1a;本文由作者参考相关资料&#xff0c;并结合自身实践和思考独立完成&#xff0c;对全文内容的准确性、完整性或…

【Linux】管道命令

命令执行的时候有时会输出数据&#xff0c;有的命令输出的数据太繁杂了。 那么我们怎么去筛选这些信息来得到我们所想要的格式&#xff1f; 这就牵涉到管道命令的问题了&#xff08;pipe&#xff09;&#xff0c;管道命令使用的是【|】这个界定符号。另外&#xff0c;管道命令与…