写一个教师信息管理系统的c++可视化程序,可以能够在界面显示教室信息的记录,通过菜单能够对数据库进行 增、删、改的操作。教室信息,包括教室容纳人数、教室空闲时间、教室设备等;

时间: 2023-12-06 16:44:24 浏览: 47
很高兴为您提供一个简单的教师信息管理系统的C++可视化程序。这个程序使用了Qt框架,包含一个主窗口和多个对话框。这个程序能够通过菜单进行增、删、改等操作,同时在界面中显示教室信息的记录。 以下是实现这个程序的步骤: 1. 创建一个Qt Widgets Application项目,命名为TeacherInfoManagementSystem。 2. 在主窗口中添加一个QTableView用于显示教室信息的记录。这个QTableView需要使用一个QSqlTableModel来管理数据。代码如下: ```cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include <QSqlTableModel> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); // 创建一个QSqlTableModel用于管理数据 QSqlTableModel *model = new QSqlTableModel(this); model->setTable("classroom"); // 设置表名 model->select(); // 查询数据 ui->tableView->setModel(model); // 设置QTableView的模型 } MainWindow::~MainWindow() { delete ui; } ``` 3. 创建一个对话框,用于添加教室信息。这个对话框包含多个QLineEdit用于输入教室容纳人数、空闲时间和设备等信息。代码如下: ```cpp #include "addclassroomdialog.h" #include "ui_addclassroomdialog.h" AddClassroomDialog::AddClassroomDialog(QWidget *parent) : QDialog(parent), ui(new Ui::AddClassroomDialog) { ui->setupUi(this); } AddClassroomDialog::~AddClassroomDialog() { delete ui; } void AddClassroomDialog::on_buttonBox_accepted() { // 获取用户输入的教室信息 QString capacity = ui->capacityLineEdit->text(); QString freeTime = ui->freeTimeLineEdit->text(); QString equipment = ui->equipmentLineEdit->text(); // 将教室信息插入到数据库中 QSqlQuery query; query.prepare("INSERT INTO classroom (capacity, free_time, equipment) " "VALUES (:capacity, :freeTime, :equipment)"); query.bindValue(":capacity", capacity); query.bindValue(":freeTime", freeTime); query.bindValue(":equipment", equipment); query.exec(); // 发送信号告诉主窗口需要更新QTableView emit dataChanged(); } ``` 4. 在主窗口中添加一个“添加”菜单项,并在点击时打开上面创建的对话框。代码如下: ```cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include <QSqlTableModel> #include <QMessageBox> #include "addclassroomdialog.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); // 创建一个QSqlTableModel用于管理数据 QSqlTableModel *model = new QSqlTableModel(this); model->setTable("classroom"); // 设置表名 model->select(); // 查询数据 ui->tableView->setModel(model); // 设置QTableView的模型 // 添加“添加”菜单项 QAction *addAction = new QAction(tr("添加"), this); connect(addAction, &QAction::triggered, this, &MainWindow::addRecord); ui->menuBar->addAction(addAction); } MainWindow::~MainWindow() { delete ui; } void MainWindow::addRecord() { AddClassroomDialog dialog(this); connect(&dialog, &AddClassroomDialog::dataChanged, this, &MainWindow::updateModel); dialog.exec(); } void MainWindow::updateModel() { // 更新QTableView的模型 QSqlTableModel *model = qobject_cast<QSqlTableModel *>(ui->tableView->model()); if (model) model->select(); } ``` 5. 创建一个对话框,用于删除教室信息。这个对话框显示一个QComboBox,用于选择要删除的教室信息。代码如下: ```cpp #include "deleteclassroomdialog.h" #include "ui_deleteclassroomdialog.h" #include <QSqlQuery> #include <QSqlError> DeleteClassroomDialog::DeleteClassroomDialog(QWidget *parent) : QDialog(parent), ui(new Ui::DeleteClassroomDialog) { ui->setupUi(this); // 从数据库中查询教室信息,并将其添加到QComboBox中 QSqlQuery query; query.exec("SELECT * FROM classroom"); while (query.next()) { QString id = query.value(0).toString(); QString capacity = query.value(1).toString(); QString freeTime = query.value(2).toString(); QString equipment = query.value(3).toString(); QString text = QString("%1 - %2 - %3 - %4").arg(id).arg(capacity).arg(freeTime).arg(equipment); ui->classroomComboBox->addItem(text, id); } } DeleteClassroomDialog::~DeleteClassroomDialog() { delete ui; } void DeleteClassroomDialog::on_buttonBox_accepted() { // 获取用户选择的教室信息的ID QString id = ui->classroomComboBox->currentData().toString(); // 从数据库中删除该教室信息 QSqlQuery query; query.prepare("DELETE FROM classroom WHERE id = :id"); query.bindValue(":id", id); query.exec(); // 发送信号告诉主窗口需要更新QTableView emit dataChanged(); } ``` 6. 在主窗口中添加一个“删除”菜单项,并在点击时打开上面创建的对话框。代码如下: ```cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include <QSqlTableModel> #include <QMessageBox> #include "addclassroomdialog.h" #include "deleteclassroomdialog.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); // 创建一个QSqlTableModel用于管理数据 QSqlTableModel *model = new QSqlTableModel(this); model->setTable("classroom"); // 设置表名 model->select(); // 查询数据 ui->tableView->setModel(model); // 设置QTableView的模型 // 添加“添加”菜单项 QAction *addAction = new QAction(tr("添加"), this); connect(addAction, &QAction::triggered, this, &MainWindow::addRecord); ui->menuBar->addAction(addAction); // 添加“删除”菜单项 QAction *deleteAction = new QAction(tr("删除"), this); connect(deleteAction, &QAction::triggered, this, &MainWindow::deleteRecord); ui->menuBar->addAction(deleteAction); } MainWindow::~MainWindow() { delete ui; } void MainWindow::addRecord() { AddClassroomDialog dialog(this); connect(&dialog, &AddClassroomDialog::dataChanged, this, &MainWindow::updateModel); dialog.exec(); } void MainWindow::deleteRecord() { DeleteClassroomDialog dialog(this); connect(&dialog, &DeleteClassroomDialog::dataChanged, this, &MainWindow::updateModel); dialog.exec(); } void MainWindow::updateModel() { // 更新QTableView的模型 QSqlTableModel *model = qobject_cast<QSqlTableModel *>(ui->tableView->model()); if (model) model->select(); } ``` 7. 创建一个对话框,用于修改教室信息。这个对话框显示一个QComboBox,用于选择要修改的教室信息,以及多个QLineEdit用于输入新的教室容纳人数、空闲时间和设备等信息。代码如下: ```cpp #include "modifyclassroomdialog.h" #include "ui_modifyclassroomdialog.h" #include <QSqlQuery> #include <QSqlError> ModifyClassroomDialog::ModifyClassroomDialog(QWidget *parent) : QDialog(parent), ui(new Ui::ModifyClassroomDialog) { ui->setupUi(this); // 从数据库中查询教室信息,并将其添加到QComboBox中 QSqlQuery query; query.exec("SELECT * FROM classroom"); while (query.next()) { QString id = query.value(0).toString(); QString capacity = query.value(1).toString(); QString freeTime = query.value(2).toString(); QString equipment = query.value(3).toString(); QString text = QString("%1 - %2 - %3 - %4").arg(id).arg(capacity).arg(freeTime).arg(equipment); ui->classroomComboBox->addItem(text, id); } } ModifyClassroomDialog::~ModifyClassroomDialog() { delete ui; } void ModifyClassroomDialog::on_classroomComboBox_currentIndexChanged(int index) { // 当用户选择一个教室信息时,将其原有的属性显示在QLineEdit中 QString id = ui->classroomComboBox->currentData().toString(); QSqlQuery query; query.prepare("SELECT * FROM classroom WHERE id = :id"); query.bindValue(":id", id); query.exec(); if (query.next()) { ui->capacityLineEdit->setText(query.value(1).toString()); ui->freeTimeLineEdit->setText(query.value(2).toString()); ui->equipmentLineEdit->setText(query.value(3).toString()); } } void ModifyClassroomDialog::on_buttonBox_accepted() { // 获取用户选择的教室信息的ID和新的属性 QString id = ui->classroomComboBox->currentData().toString(); QString capacity = ui->capacityLineEdit->text(); QString freeTime = ui->freeTimeLineEdit->text(); QString equipment = ui->equipmentLineEdit->text(); // 更新数据库中的教室信息 QSqlQuery query; query.prepare("UPDATE classroom SET capacity = :capacity, free_time = :freeTime, equipment = :equipment " "WHERE id = :id"); query.bindValue(":capacity", capacity); query.bindValue(":freeTime", freeTime); query.bindValue(":equipment", equipment); query.bindValue(":id", id); query.exec(); // 发送信号告诉主窗口需要更新QTableView emit dataChanged(); } ``` 8. 在主窗口中添加一个“修改”菜单项,并在点击时打开上面创建的对话框。代码如下: ```cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include <QSqlTableModel> #include <QMessageBox> #include "addclassroomdialog.h" #include "deleteclassroomdialog.h" #include "modifyclassroomdialog.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); // 创建一个QSqlTableModel用于管理数据 QSqlTableModel *model = new QSqlTableModel(this); model->setTable("classroom"); // 设置表名 model->select(); // 查询数据 ui->tableView->setModel(model); // 设置QTableView的模型 // 添加“添加”菜单项 QAction *addAction = new QAction(tr("添加"), this); connect(addAction, &QAction::triggered, this, &MainWindow::addRecord); ui->menuBar->addAction(addAction); // 添加“删除”菜单项 QAction *deleteAction = new QAction(tr("删除"), this); connect(deleteAction, &QAction::triggered, this, &MainWindow::deleteRecord); ui->menuBar->addAction(deleteAction); // 添加“修改”菜单项 QAction *modifyAction = new QAction(tr("修改"), this); connect(modifyAction, &QAction::triggered, this, &MainWindow::modifyRecord); ui->menuBar->addAction(modifyAction); } MainWindow::~MainWindow() { delete ui; } void MainWindow::addRecord() { AddClassroomDialog dialog(this); connect(&dialog, &AddClassroomDialog::dataChanged, this, &MainWindow::updateModel); dialog.exec(); } void MainWindow::deleteRecord() { DeleteClassroomDialog dialog(this); connect(&dialog, &DeleteClassroomDialog::dataChanged, this, &MainWindow::updateModel); dialog.exec(); } void MainWindow::modifyRecord() { ModifyClassroomDialog dialog(this); connect(&dialog, &ModifyClassroomDialog::dataChanged, this, &MainWindow::updateModel); dialog.exec(); } void MainWindow::updateModel() { // 更新QTableView的模型 QSqlTableModel *model = qobject_cast<QSqlTableModel *>(ui->tableView->model()); if (model) model->select(); } ``` 9. 在程序入口函数中创建一个QSqlDatabase对象,并连接到SQLite数据库。代码如下: ```cpp #include "mainwindow.h" #include <QApplication> #include <QSqlDatabase> #include <QSqlError> int main(int argc, char *argv[]) { QApplication a(argc, argv); // 连接到SQLite数据库 QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("teacher_info.db"); if (!db.open()) { QMessageBox::critical(nullptr, QObject::tr("无法打开数据库"), QObject::tr("无法打开数据库,请检查数据库文件是否存在或者是否有足够的权限。\n" "错误信息:%1").arg(db.lastError().text())); return -1; } MainWindow w; w.show(); return a.exec(); } ``` 完成了以上步骤,编译并运行程序,即可看到一个简单的教师信息管理系统的界面。您可以通过菜单进行增、删、改等操作,并在界面中显示教室信息的记录。

相关推荐

最新推荐

recommend-type

汽车租赁信息管理系统源代码 c++.docx

(3)对原有的车辆信息进行修改:可根据查询结果对相应的记录进行修改。 (4)显示已存的车辆信息:可按车辆类别、车辆的出租价格、车牌号、品牌型号进行查询。 (5)删除原有的车辆信息:主要完成车辆信息的删除。...
recommend-type

诊所信息管理系统C++课程设计报告.doc

模拟诊所信息管理系统就是对存储患者信息以及医生信息在个人PC上的编程实现。本系统采用了用户身份的注册、登陆、增加信息、查询信息、帐单信息以及统计所有患者的总费用等功能。并分析在现实生活中遇到的问题并得到...
recommend-type

C++学校人员信息管理系统课程设计.doc

一个用C++写的学校人员管理系统,适合大一大二的课程设计,里面运用到了链表、文件读写等一些C++基本语法操作
recommend-type

C++获得其他程序窗体控件中信息的方法

主要介绍了C++获得其他程序窗体控件中信息的方法,涉及windows控件句柄的获取技巧,需要的朋友可以参考下
recommend-type

C++ 学生成绩管理系统设计报告书

个人课程设计报告书(内含源码) ...可以对已有的学生信息进行修改。 (5)学生基本信息的删除。 (6)对该班各科成绩进行分析;对学生成绩进行统计(包括最高分,最低分,排序,平均成绩,及格率和需要补考的学生)
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章

![:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章](https://img-blog.csdnimg.cn/img_convert/69b98e1a619b1bb3c59cf98f4e397cd2.png) # 1. 目标检测算法概述 目标检测算法是一种计算机视觉技术,用于识别和定位图像或视频中的对象。它在各种应用中至关重要,例如自动驾驶、视频监控和医疗诊断。 目标检测算法通常分为两类:两阶段算法和单阶段算法。两阶段算法,如 R-CNN 和 Fast R-CNN,首先生成候选区域,然后对每个区域进行分类和边界框回归。单阶段算法,如 YOLO 和 SSD,一次性执行检
recommend-type

info-center source defatult

这是一个 Cisco IOS 命令,用于配置 Info Center 默认源。Info Center 是 Cisco 设备的日志记录和报告工具,可以用于收集和查看设备的事件、警报和错误信息。该命令用于配置 Info Center 默认源,即设备的默认日志记录和报告服务器。在命令行界面中输入该命令后,可以使用其他命令来配置默认源的 IP 地址、端口号和协议等参数。
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。