QT:搭配tablewidget的数据库编程

2023-10-08 18:30

本文主要是介绍QT:搭配tablewidget的数据库编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

pro:QT        += core gui sql

widget.ui

main.cpp

#include "widget.h"
#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);Widget w("./student.db");w.show();return a.exec();
}

widget.h

#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include <QSqlDatabase>  //数据库连接
#include <QSqlQuery>     //执行SQL语句
#include <QSqlError>     //具体错误
#include <QDebug>namespace Ui {
class Widget;
}class Widget : public QWidget
{Q_OBJECTpublic:explicit Widget(QString filename,QWidget *parent = 0);~Widget();void showInfo();private slots:void on_pb_add_clicked();void on_pb_update_clicked();void on_pb_delete_clicked();private:Ui::Widget *ui;QString db_file_name;     //数据库文件名QSqlDatabase db_student;   //数据库名
};#endif // WIDGET_H

widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include <QFile>
#include <QMessageBox>Widget::Widget(QString filename,QWidget *parent) :QWidget(parent),ui(new Ui::Widget),db_file_name(filename)
{ui->setupUi(this);setWindowTitle("学生信息系统");setFixedSize(800,600);QFile file(db_file_name);if(!file.exists()){db_student = QSqlDatabase::addDatabase("QSQLITE");  //建立到SQLITE数据库的连接db_student.setDatabaseName(db_file_name);   //设置数据库文件名//打开数据库if (!db_student.open()){qDebug() << "打开数据库失败1";}else{qDebug() << "打开数据库成功1";}//QSqlQuery用于SQL语句的执行,对返回结果的使用//要指定使用的数据库的连接 db_studentQSqlQuery sql_query(db_student);//创建数据库的表QString str_query = "create table Student (id varchar(64) PRIMARY KEY, name varchar(64), gender varchar(64), age int)";//执行SQL语句if (!sql_query.exec(str_query)){qDebug() << str_query << " failed";qDebug() << sql_query.lastError().text();}//向数据库的student表插入数据 方式1str_query = "insert into Student values('2309260001', '张三', '男', 15)";if (!sql_query.exec(str_query)){qDebug() << str_query << " failed";qDebug() << sql_query.lastError().text();}//向数据库的student表插入数据 方式2str_query = "insert into Student values(?,?,?,?)";//准备SQL的语句sql_query.prepare(str_query);//绑定待定的数据,取代SQL语句里的 "?"sql_query.addBindValue("2309260002");sql_query.addBindValue("李四");sql_query.addBindValue("男");sql_query.addBindValue(16);if (!sql_query.exec()){qDebug() << str_query << " failed";qDebug() << sql_query.lastError().text();}//向数据库的student表插入数据 方式3str_query = "insert into Student values(:id, :name, :gender, :age)";sql_query.prepare(str_query);//绑定待定的数据sql_query.bindValue(":id", "2309260003");sql_query.bindValue(":name", "王五");sql_query.bindValue(":gender", "女");sql_query.bindValue(":age", 17);if (!sql_query.exec()){qDebug() << str_query << " failed";qDebug() << sql_query.lastError().text();}}else{db_student = QSqlDatabase::addDatabase("QSQLITE");//设置数据库文件的名字db_student.setDatabaseName(db_file_name);//打开数据库if (!db_student.open()){qDebug() << "打开数据库失败2";}else{qDebug() << "打开数据库成功2";}}ui->tableWidget->setColumnCount(4);  //设置列数为4QStringList list;list << "学号" << "姓名" << "性别" << "年龄";ui->tableWidget->setHorizontalHeaderLabels(list);//显示数据库的内容showInfo();}Widget::~Widget()
{delete ui;
}void Widget::showInfo()
{QSqlQuery sql_query(db_student);  //连接数据库,执行SQL操作QString str_query = "select * from Student";if(!sql_query.exec(str_query)){QMessageBox::information(this,"数据库操作错误",sql_query.lastError().text());return;}QList<QStringList> lists;  //链表while(sql_query.next()){QStringList tmp;for(int i = 0;i < 4;i++){tmp << sql_query.value(i).toString();   //value为一条数据中的一个,tmp存放一整条数据:学号 、姓名 、性别 、年龄}lists.append(tmp);    //存放所有数据(全部条),lists存放的条数为数据库的行数(一条为一行)}ui->tableWidget->setRowCount(lists.size());  //根据数据库里的记录的条数来设置行数//设置显示的数据库记录的内容for(int i = 0;i < lists.size();i++)  //行{for(int j = 0;j < 4;j++)   //列{ui->tableWidget->setItem(i,j,(new QTableWidgetItem(lists.at(i).at(j))));  //第i条第j个数据的内容}QTableWidgetItem *item = ui->tableWidget->item(i,0);  //设置id不能被用户编辑item->setFlags(item->flags() & (~Qt::ItemIsEditable));}
}//新增
void Widget::on_pb_add_clicked()
{if(ui->pb_add->text() == "新增"){int row = ui->tableWidget->rowCount();  //获取实际行数,三条数据为3行ui->tableWidget->insertRow(row);    //增加行数,索引从0开始为第一行,索引为3实际为第4行ui->pb_add->setText("提交");ui->pb_delete->setEnabled(false);ui->pb_update->setEnabled(false);}else{int row = ui->tableWidget->rowCount();  //新增一行后获取行数row--;    //索引要减一才为所在新增行QSqlQuery sql_query(db_student);QString str_query = "insert into Student values(?,?,?,?)";sql_query.prepare(str_query);int count = 0;sql_query.addBindValue(ui->tableWidget->item(row,count++)->data(0).toString());  //idsql_query.addBindValue(ui->tableWidget->item(row,count++)->data(0).toString());  //namesql_query.addBindValue(ui->tableWidget->item(row,count++)->data(0).toString());  //gendersql_query.addBindValue(ui->tableWidget->item(row,count++)->data(0).toInt());     //ageif(!sql_query.exec()){qDebug() << str_query << " failed";qDebug() << sql_query.lastError().text();}ui->pb_add->setText("新增");ui->pb_delete->setEnabled(true);ui->pb_update->setEnabled(true);showInfo();  //刷新主界面的显示}
}//修改
void Widget::on_pb_update_clicked()
{int row = ui->tableWidget->currentRow();  //用户点击的所在行qDebug() << "row = " << row;if(row < 0){qDebug() << "wrong row number = " << row;return;}QSqlQuery sql_query(db_student);QString str_query = "update Student set name = ?,gender = ?,age = ? where id = ?";sql_query.prepare(str_query);sql_query.addBindValue(ui->tableWidget->item(row,1)->data(0).toString());  //name,所在行的索引为1的数据sql_query.addBindValue(ui->tableWidget->item(row,2)->data(0).toString());  //gendersql_query.addBindValue(ui->tableWidget->item(row,3)->data(0).toInt());     //agesql_query.addBindValue(ui->tableWidget->item(row,0)->data(0).toString());  //idif(!sql_query.exec()){qDebug() << str_query << " failed";qDebug() << sql_query.lastError().text();}showInfo();
}//删除
void Widget::on_pb_delete_clicked()
{int row = ui->tableWidget->currentRow();  //用户点击的所在行qDebug() << "row = " << row;if(row < 0){qDebug() << "wrong row number = " << row;return;}QSqlQuery sql_query(db_student);QString str_query = "delete from Student where id = ?";sql_query.prepare(str_query);sql_query.addBindValue(ui->tableWidget->item(row,0)->data(0).toString());  //idif(!sql_query.exec()){qDebug() << str_query << " failed";qDebug() << sql_query.lastError().text();}showInfo();}

结果

新增

修改

删除

这篇关于QT:搭配tablewidget的数据库编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/167201

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是