开发一个员工信息管理系统
一、项目具体要求:
1、用qt开发界面,数据库用QSqlite 数据库文件名:demostudent.db
2、通过界面能够查看到数据库中员工信息表中内容,包括员工姓名、年龄、性别、
成绩、生日、基本工资和照片。
3、能够查看指定记录,修改和编辑员工信息
4、员工信息中包含照片,界面上可以显示学员照片并且可以修改学员照片
5、通过界面可增加员工记录,可以删除指定的学员记录
二、项目界面展示
1、主界面:通过openDB按钮打开指定的数据库文件,将数据库表中的学员信息显示在主界面中tableView中。
其它的按钮依次是 插入按钮、编辑当前记录和删除指定记录
点击upSalary按钮,所有学员的基本工资增加1000
2、编辑学员信息的界面
单击编辑按钮或者双击某一个记录,则弹出如下编辑窗口
编辑窗口通过相关控件显示指定的记录各个字段的数据,包括照片信息
修改相关数据之后,点击ok按钮之后,则新数据更新到数据库中
通过setPhoto和clearPhoto两个按钮可以设置和修改照片
3、增加学员信息的界面
通过界面相关控件录入员工的信息,包括设置照片。
点击ok按钮,将学员信息插入到数据库表中。
三、项目代码实现:
1、项目中主要为两个类文件,描述界面的类文件mainWidget
和描述插入和编辑界面的类文件wDialogData
2、mainWidget类文件代码如下:
mainWidget.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QSqlDatabase>
#include <QSqlQueryModel>
#include <QItemSelectionModel>
namespace Ui {
class MainWindow;
}
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
explicit MainWindow(QWidget *parent = 0);
~MainWindow();
private slots:
void on_actOpenDB_triggered();
void on_actInsert_triggered();
void on_actEdit_triggered();
void on_tableView_doubleClicked(const QModelIndex &index);
void on_actDelete_triggered();
void on_actUpsalary_triggered();
private:
Ui::MainWindow *ui;
QSqlDatabase db;
QSqlQueryModel *theModel;
QItemSelectionModel *theSelection;
void openTable();
void updateRecord(int recNo);
};
#endif // MAINWINDOW_H
mainWidget.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"