QT表格显示MYSQL数据库源码分析(七)
一. 连接MySQL数据库
首先,创建了一个QSqlDatabase对象,并设置数据库类型为"QMYSQL"。然后,它设置了数据库的主机名,端口号,数据库名,用户名和密码。最后,尝试打开数据库连接,并根据连接是否成功输出相应的信息。如果连接失败就会弹出警告框并输出错误信息
QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");db.setHostName("47.116.118.86"); //连接数据库主机名,这里需要注意(若填的为”127.0.0.1“,出现不能连接,则改为localhost)db.setPort(3306); //连接数据库端口号,与设置一致db.setDatabaseName("qtsql"); //连接数据库名,与设置一致db.setUserName("qt"); //数据库用户名,与设置一致db.setPassword("zhongkeruihe"); //数据库密码,与设置一致bool ok = db.open();if (ok){// QMessageBox::information(this, "infor", "success");qDebug()<<"success";}else {QMessageBox::information(this, "警告!", "DataBase Open Failed,Check whether there is a database or whether the parameters are correct!!!");qDebug()<<"error open database because"<<db.lastError().text();//ui->label->setText(db.lastError().text());}
二. 查询表中数据并在tableView中显示
定义一个成员函数,属于一个名为database的类,这个函数的作用是从数据库中查询所有的数据,并将结果显示在一个名为tableView的表格视图上。具体步骤是:
1. 创建一个QSqlQueryModel对象,命名为tableModel。QSqlQueryModel是Qt框架中的一个模型类,用于处理数据库查询结果。
2. 定义一个字符串strSelectData,内容是SQL查询语句"select * from qtdata"。这条语句表示从名为qtdata的表中选择所有列的数据
3. 使用tableModel->setQuery(strSelectData)方法,将查询语句设置到tableModel对象中
4. 调用ui->tableView->setModel(tableModel)方法,将tableModel设置为tableView的模型。这样,tableView就会显示tableModel中的查询结果。
//查询所有并放入表中
SelectAllPushTableData();void database::SelectAllPushTableData(){tableModel = new QSqlQueryModel;//定义一个数据库模型,指定父对象QString strSelectData = "select * from qtdata";tableModel->setQuery(strSelectData);ui->tableView->setModel(tableModel);
}
三. 定义多个槽函数
定义多个按钮对应的槽函数,比如更新数据,插入数据和删除数据等。
bool database::clearDBTable()这个函数作用是清除数据库表中的数据,并且按钮按下后,会弹出弹框,提醒是否确认选择
void database::SelectData()在设定的时间范围内查找这一范围内的表中的数据
void database::on_select_val_bt_clicked()在两个下拉框值的范围内搜索表中在这一范围内的数据,并且在tableview中显示
#include "database.h"
#include "ui_database.h"#include <QMessageBox>
#include <QDebug>
#include <QSqlError>database::database(QWidget *parent) :QWidget(parent),ui(new Ui::database)
{ui->setupUi(this);qDebug()<<QSqlDatabase::drivers();
// QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
// db.setDatabaseName("test");QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");db.setHostName("47.116.118.86"); //连接数据库主机名,这里需要注意(若填的为”127.0.0.1“,出现不能连接,则改为localhost)db.setPort(3306); //连接数据库端口号,与设置一致db.setDatabaseName("qtsql"); //连接数据库名,与设置一致db.setUserName("qt"); //数据库用户名,与设置一致db.setPassword("zhongkeruihe"); //数据库密码,与设置一致// db.setHostName("47.116.118.86");
// db.setPort(3306);
// db.setDatabaseName("qtsql");
// db.setUserName("qt");
// db.setPassword("zhongkeruihe");bool ok = db.open();if (ok){// QMessageBox::information(this, "infor", "success");qDebug()<<"success";}else {QMessageBox::information(this, "警告!", "DataBase Open Failed,Check whether there is a database or whether the parameters are correct!!!");qDebug()<<"error open database because"<<db.lastError().text();//ui->label->setText(db.lastError().text());}//查询所有并放入表中SelectAllPushTableData();//初始化表格 格式
// ui->tableView->setColumnWidth(0,80);
// ui->tableView->setColumnWidth(1,150);
// ui->tableView->setColumnWidth(2,70);
// ui->tableView->setColumnWidth(3,70);
// ui->tableView->setColumnWidth(4,70);
// ui->tableView->setColumnWidth(5,70);
// ui->tableView->setColumnWidth(6,70);
// ui->tableView->setColumnWidth(7,70);/*初始化下拉框*/ui->comboBox_2->addItem("温度");ui->comboBox_2->addItem("湿度");ui->comboBox_2->addItem("光照强度");ui->comboBox_2->addItem("二氧化碳");ui->comboBox->addItem("水位");ui->comboBox_2->addItem("位置");ui->comboBox_2->addItem("亮度");ui->comboBox_2->addItem("通风");ui->comboBox_2->addItem("喷淋");ui->comboBox_2->addItem("雾培");ui->comboBox_2->addItem("水加热");ui->comboBox_2->addItem("位置变化");ui->comboBox_2->addItem("温度变化");/*设置日期查询的初始化*/ui->dateTimeEdit_2->setDateTime(QDateTime::currentDateTime().addSecs(0));ui->dateTimeEdit->setDateTime(QDateTime::currentDateTime().addSecs(0));setFixedSize(750,650);setWindowTitle("——数据库管理平台——");
}void database::SelectAllPushTableData(){tableModel = new QSqlQueryModel;//定义一个数据库模型,指定父对象QString strSelectData = "select * from qtdata";tableModel->setQuery(strSelectData);ui->tableView->horizontalHeader()->setDefaultAlignment(Qt::AlignCenter);ui->tableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);ui->tableView->setModel(tableModel);}//void database::UpdataToDataBase(QString Stemp,QString Shumi,QString Slight,QString Ssoil,QString Smq2,QString Srain)
//{
// float val[6];// val[0] = Stemp.toFloat();
// val[1] = Shumi.toFloat();
// val[2] = Slight.toFloat();// val[3] = Ssoil.toFloat();
// val[4] = Smq2.toFloat();
// val[5] = Srain.toFloat();// // qDebug()<<val[0]<<" "<<val[1]<<" "<<val[2]<<" "<<val[3]<<" "<<val[4]<<" "<<val[5]<<" "<<" ";// //插入
// insertData(val);// //查询并全部显示
// SelectAllPushTableData();//}插入数据
//bool database::insertData(float val[14])
//{
// QSqlQuery query;// //QDateTime currentTime = QDateTime::currentDateTime();// QString stInsertData = "insert into qtdata values (?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
// query.prepare(stInsertData);//准备SQL语句// query.addBindValue(val[0]);
// query.addBindValue(val[1]);
// query.addBindValue(val[2]);
// query.addBindValue(val[3]);
// query.addBindValue(val[4]);
// query.addBindValue(val[5]);
// query.addBindValue(val[6]);
// query.addBindValue(val[7]);
// query.addBindValue(val[8]);
// query.addBindValue(val[9]);
// query.addBindValue(val[10]);
// query.addBindValue(val[11]);
// query.addBindValue(val[12]);
// query.addBindValue(QDateTime::currentDateTime().addSecs(0).toString("yyyy-MM-dd hh:mm:ss"));
// // query.addBindValue()方法将各个值绑定到SQL语句中的占位符// // query.exec()执行SQL语句,如果执行失败,将输出错误信息
// if(!query.exec())
// {
// qDebug()<<query.lastError();
// }
// return true;
//}//清空表
bool database::clearDBTable()
{QSqlQuery query;QString strClearDB = "delete from qtdata";//创建一个消息框,询问用户是否确认操作QMessageBox::StandardButton reply;reply = QMessageBox::question(this,"清除数据","确定要清除表中数据?",QMessageBox::Yes|QMessageBox::No);//根据用户的选择执行相应的操作if (reply == QMessageBox::Yes){query.prepare(strClearDB);}else if(reply == QMessageBox::No){}if(!query.exec()){qDebug()<<query.lastError();}return true;
}//日期查询
void database::SelectData()
{tableModel = new QSqlQueryModel;//定义一个数据库模型,指定父对象QString startTime = ui->dateTimeEdit->text();QString startTime2 = ui->dateTimeEdit_2->text();//查询操作QString strSelectData = "select *from qtdata where CurrenTime between '"+startTime+"' and '"+startTime2+"';";tableModel->setQuery(strSelectData);ui->tableView->horizontalHeader()->setDefaultAlignment(Qt::AlignCenter);ui->tableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);ui->tableView->setModel(tableModel);
}database::~database()
{delete ui;
}//退出
void database::on_exit_bt_clicked()
{this->close();
}//查询按钮 ->查询指定日期
void database::on_select_data_bt_clicked()
{SelectData();
}//显示所有
void database::on_displayAll_bt_clicked()
{SelectAllPushTableData();
}//now
void database::on_now_bt_clicked()
{//当前时间ui->dateTimeEdit_2->setDateTime(QDateTime::currentDateTime().addSecs(0));
}
//最近一天
void database::on_currDay_bt_clicked()
{//上一天ui->dateTimeEdit->setDateTime(QDateTime::currentDateTime().addSecs(-3600*24));//当前时间ui->dateTimeEdit_2->setDateTime(QDateTime::currentDateTime().addSecs(0));SelectData();
}
//最近三天
void database::on_currThDay_bt_clicked()
{//三天前天ui->dateTimeEdit->setDateTime(QDateTime::currentDateTime().addSecs(-3600*24*3));//当前时间ui->dateTimeEdit_2->setDateTime(QDateTime::currentDateTime().addSecs(0));SelectData();
}
//最近一周
void database::on_currWeek_bt_clicked()
{//七天前ui->dateTimeEdit->setDateTime(QDateTime::currentDateTime().addSecs(-3600*24*7));//当前时间ui->dateTimeEdit_2->setDateTime(QDateTime::currentDateTime().addSecs(0));SelectData();
}//条件查询
void database::on_select_val_bt_clicked()
{//获取索引值QString strNum = ui->comboBox_2->currentText();//获取上下值QString downNum = ui->spinBox->text();QString upNum = ui->spinBox_2->text();//查询操作QString strSelectData = "select *from qtdata where "+strNum+" >= "+downNum+" && "+strNum+"<="+upNum+";";tableModel->setQuery(strSelectData);ui->tableView->horizontalHeader()->setDefaultAlignment(Qt::AlignCenter);ui->tableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);ui->tableView->setModel(tableModel);
}//添加
/*
void database::on_add_bt_clicked()
{//插入数据// insertData();//查询并显示SelectAllPushTableData();
}*///清空表按钮
void database::on_clear_bt_clicked()
{clearDBTable();SelectAllPushTableData();
}
相关文章:
QT表格显示MYSQL数据库源码分析(七)
一. 连接MySQL数据库 首先,创建了一个QSqlDatabase对象,并设置数据库类型为"QMYSQL"。然后,它设置了数据库的主机名,端口号,数据库名,用户名和密码。最后,尝试打开数据库连接&#x…...
excel系列(三) - 利用 easyexcel 快速实现 excel 文件导入导出
一、介绍 在上篇文章中,我们介绍了 easypoi 工具实现 excel 文件的导入导出。 本篇我们继续深入介绍另一款更优秀的 excel 工具库:easyexcel 。 二、easyexcel easyexcel 是阿里巴巴开源的一款 excel 解析工具,底层逻辑也是基于 apache p…...
探索前后端数据传输模式:Java、Go与Python的实践20240719
深入解析前后端数据传输:Java、Go与Python的实践 引言 在当今的互联网时代,用户对Web应用的性能和交互体验有着越来越高的要求。无论是信息展示型网站还是复杂的企业应用,前后端数据传输的效率和模式选择都至关重要。本文将深入探讨三种主流…...
【YashanDB知识库】yac修改参数后关闭数据库hang住
【标题】yac修改参数后关闭数据库hang住 【问题分类】性能优化 【关键词】YashanDB, yac, shutdown hang 【问题描述】修改yac参数后执行shutdown immediate,数据库hang住。 【问题原因分析】 Shutdown操作时,线程在获取gInstance->trigger->s…...
提升网站性能:ThinkPHP6中如何实现Mysql分页查询
随着互联网的快速发展,web应用程序的开发也越来越复杂。而分页查询是web应用程序中常见的功能之一。thinkphp6是一个web框架,可以帮助开发人员快速开发应用程序。在本文中,我们将讨论如何在thinkphp6中使用mysql进行分页查询。 首先…...
Python:Flask自定义URL路由参数过滤器
目录 简单的例子手动类型转换自动类型转换自定义路由过滤器 简单的例子 先看一个简单的例子,GET请求需要传递一个参数,我们直接获取的是字符串 from flask import Flaskapp Flask(__name__)app.get("/<value>") def index(value):ret…...
闭包与装饰器
一.闭包: 闭包是Python中的一种高级特性,指的是在函数内部定义了另外一个函数,并返回了这个内部函数作为函数对象,同时还保存了外层函数的状态信息。这个内部函数可以依赖外层函数的变量和参数,而且外层函数返回的是这…...
DNS服务器的搭建
1、DNS服务器端软件 DNS 的域名解析都是 udp/53 . 主从之间的数据传输默认使 ⽤tcp/53 DNS服务器端软件: Bind是⼀款开放源码的DNS服务器软件,Bind由美国加州⼤学Berkeley(伯克 利)分校开发和维护的,全名为Berkele…...
【JavaScript】点击穿透
点击穿透是指在某些场景下,⽤户在快速点击⻚⾯元素时,由于某些原因(例如⽹络延迟), 在前⼀个元素上的点击事件还没有完成时,下⼀个元素的点击事件就已经触发了,导致⽤户感 觉到⻚⾯点击⽆效或者…...
[Linux]Mysql之主从同步
AB复制 一、主从复制概述 主从复制,是用来建立一个和主数据库完全一样的数据库环境,称为从数据库;主数据库一般是准实时的业务数据库。 主从复制的作用 1.做数据的热备,作为后备数据库,主数据库服务器故障后…...
DAY21-二叉树
LeetCode538.把二叉搜索树转换为累加树 public TreeNode convertBST(TreeNode root) {reverseIn(root);return root;}public Integer value0,flag0;public void reverseIn(TreeNode root) {if(rootnull) return ;reverseIn(root.right);if(flag0) {valueroot.val;flag1;}else {…...
java面试-场景题
一、集合 1. java中如何给一个超大的一个亿左右的list数据去重? 我当时的回答是使用HashSet或Stream流的distinct语法。但是面试官好像更注重内存的消耗问题。 使用HashSet: HashSet 是一个不允许有重复元素的集合。你可以将List中的元素添加到HashSe…...
【TORCH】matplotlib绘制一条横线的两种方法
在创建图形和数据可视化时,你提到的两种方法都用于绘制特定的线条,但它们在实现方式上有所不同。我将逐一解释这两种方法的具体含义和用途。 1. 使用列表创建常数值的线条 y [1] * len(x)这行代码生成了一个列表 y,其长度与 x 相同&#x…...
深入浅出mediasoup—WebRtcTransport
mediasoup 提供了多种 transport,包括 WebRtcTransport、PipeTransport、DirectTransport、PlainTransport 等,用来实现不同目的和场景的媒体通信。WebRtcTransport 是 mediasoup 实现与 WebRTC 客户端进行媒体通信的对象,是 mediasoup 最重要…...
如何让局域网中的其他电脑访问VMWare虚拟机上的Windows虚拟系统
场景描述 事情是这样的,我在我的主机(Win10)上搭建了一个VMWare虚拟机,并安装了Windows Server的虚拟系统,想用它来测试一些东西。但是呢,我发现尽管我的主机可以愉快地跟这个服务器对话,可办公…...
旧电脑回收前怎么清除数据
随着技术的快速更新换代,很多人的电脑也会不断的更新升级,比如给电脑升级硬件或是更换新电脑,从而获得更好的性能和体验。那么旧的电脑及电脑部件怎么处理更安全呢?我们要确保旧电脑上的个人数据被彻底清除干净,这样可…...
python——TinyDB
TinyDB 是一个轻量级的纯 Python 写入的文档数据库。它不需要单独的服务器进程或复杂的配置,只需导入模块即可开始使用。TinyDB 适合于小型项目或测试用例,它的数据存储在本地文件中。 TinyDB 的基本 API 和使用方式: 初始化数据库 from tin…...
【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第三篇 嵌入式Linux驱动开发篇-第三十八章 驱动模块编译进内核
i.MX8MM处理器采用了先进的14LPCFinFET工艺,提供更快的速度和更高的电源效率;四核Cortex-A53,单核Cortex-M4,多达五个内核 ,主频高达1.8GHz,2G DDR4内存、8G EMMC存储。千兆工业级以太网、MIPI-DSI、USB HOST、WIFI/BT…...
Mailspring搭建安装教程:打造个性邮件体验
Mailspring搭建安装教程步骤!如何选择电子邮件服务商? Mailspring作为一款功能强大、界面友好的邮件客户端,成为了许多用户的首选。AokSend将为大家提供详细的Mailspring搭建安装教程,帮助您打造个性化的邮件体验。 Mailspring搭…...
【分布式锁】Redission实现分布式锁
接着上一节,我们遇到了超卖的问题,并通过Redis实现分布式锁,进行了解决。本节 我将换一种方式实现分布式锁。 前提: nginx、redis、nacos 模块1: provider-and-consumer 端口 8023 模块2 rabbitmq-consumer 端口 8021 …...
Python爬虫实战:研究feedparser库相关技术
1. 引言 1.1 研究背景与意义 在当今信息爆炸的时代,互联网上存在着海量的信息资源。RSS(Really Simple Syndication)作为一种标准化的信息聚合技术,被广泛用于网站内容的发布和订阅。通过 RSS,用户可以方便地获取网站更新的内容,而无需频繁访问各个网站。 然而,互联网…...
【网络安全产品大调研系列】2. 体验漏洞扫描
前言 2023 年漏洞扫描服务市场规模预计为 3.06(十亿美元)。漏洞扫描服务市场行业预计将从 2024 年的 3.48(十亿美元)增长到 2032 年的 9.54(十亿美元)。预测期内漏洞扫描服务市场 CAGR(增长率&…...
【算法训练营Day07】字符串part1
文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接:344. 反转字符串 双指针法,两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...
使用Matplotlib创建炫酷的3D散点图:数据可视化的新维度
文章目录 基础实现代码代码解析进阶技巧1. 自定义点的大小和颜色2. 添加图例和样式美化3. 真实数据应用示例实用技巧与注意事项完整示例(带样式)应用场景在数据科学和可视化领域,三维图形能为我们提供更丰富的数据洞察。本文将手把手教你如何使用Python的Matplotlib库创建引…...
日常一水C
多态 言简意赅:就是一个对象面对同一事件时做出的不同反应 而之前的继承中说过,当子类和父类的函数名相同时,会隐藏父类的同名函数转而调用子类的同名函数,如果要调用父类的同名函数,那么就需要对父类进行引用&#…...
掌握 HTTP 请求:理解 cURL GET 语法
cURL 是一个强大的命令行工具,用于发送 HTTP 请求和与 Web 服务器交互。在 Web 开发和测试中,cURL 经常用于发送 GET 请求来获取服务器资源。本文将详细介绍 cURL GET 请求的语法和使用方法。 一、cURL 基本概念 cURL 是 "Client URL" 的缩写…...
华为OD最新机试真题-数组组成的最小数字-OD统一考试(B卷)
题目描述 给定一个整型数组,请从该数组中选择3个元素 组成最小数字并输出 (如果数组长度小于3,则选择数组中所有元素来组成最小数字)。 输入描述 行用半角逗号分割的字符串记录的整型数组,0<数组长度<= 100,0<整数的取值范围<= 10000。 输出描述 由3个元素组成…...
从数据报表到决策大脑:AI重构电商决策链条
在传统电商运营中,决策链条往往止步于“数据报表层”:BI工具整合历史数据,生成滞后一周甚至更久的销售分析,运营团队凭经验预判需求。当爆款突然断货、促销库存积压时,企业才惊觉标准化BI的决策时差正成为增长瓶颈。 一…...
【设计模式】1.简单工厂、工厂、抽象工厂模式
every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 以下是 简单工厂模式、工厂方法模式 和 抽象工厂模式 的 Python 实现与对比,结合代码示例和实际应用场景说明: 1. 简单工厂模式&a…...
AT_abc409_e [ABC409E] Pair Annihilation
AT_abc409_e [ABC409E] Pair Annihilation 赛时没开longlong挂了。 思路 首先我们可以把这棵树转化为一颗有根树,且所有电子的都朝根节点移动。 那么接下来我们就需要选择一个最优的树根。 考虑换根dp。 但是可以发现换根时答案其实是没有变化的。 我们设 f…...
