教务管理系统(C++与MySQL交互)

项目介绍:

        这个项目是楼主上学期手搓的数据库课程设计,搁置了蛮久的,今天抽空写一下总结,分享给大家一起学习与交流!

        本项目通过将C++和MYSQL相结合,实现教务管理系统登录和注册,并划分教师端和学生端,教师端实现对学生和课程的增删改查,学生端实现选课。整个项目使用纯C++代码编写,没有使用框架,所以界面比较简陋,有能力的可以自行完善。


项目思维导图:

        

4506353189be963df306b03f6979c861.png


开发环境:

Windows 10

开发工具:

Virtual Studio 2019

开发语言:

C++

MYSQL (5.7.44)

依赖配置:

        1、复制MYSQL安装目录下\lib\libmysql.dll文件到C:\Windows\System32

        2、打开项目属性>VC++目录,将MYSQL安装目录下include和lib文件夹路径分别添加到下面两个目录

50d9eebd47873e3d4dff5d7014056a35.png


数据库表结构:

department表:部门表

e3ad2df71491b645e66c7dee321c0a80.png

course表:课程表

65b8145875536e91e1548849e41b88cd.png

sc表:选课表

25f80e261dba68da8a46565df87a7078.png

teacher表:教师表

63c457cf9953fc387d048357a12ee12b.png

student表:学生表

b965389452108b3aebb1976aad7df716.png

        这些表不需要手动创建,本系统连接数据库成功后会自动创建。tip:部门表对应学生的专业,因为变动比较小,所以我在C++代码中将数据写死了,有需要可以自己在代码中修改或增加对应增删函数)


主要代码实现:

        首先根据数据库中的表设计部门类、老师类、学生类、课程类、选课类。分别用于存储数据库读取的数据

/* 
    table.h

    by 打印两年半的HelloWorld
*/

#pragma once
#include<iostream>
#include<string>
using namespace std;
class Base {
public:
	Base();
	Base(string number,string name);
	void SetNumber(string number);
	string GetNumber();
	void SetName(string name);
	string GetName();
protected:
	string number;
	string name;
};

class Person:public Base{
public:
	Person();
	Person(string number, string name, string sex, string age, string dname, string password);
	void SetSex(string sex);
	string GetSex();
	void SetAge(string age);
	string GetAge();
	void SetDname(string dname);
	string GetDname();
	void SetPassword(string password);
	string GetPassword();
protected:	
	string sex;
	string age;
	string dname;
	string password;
};

class Course:public Base{
public:
	Course();
	Course(string number, string cname, string tname);
	void SetTname(string tname);
	string GetTname();
	bool status;//选课状态
private:
	string tname;
	
};

class Department:public Base {
public:
	Department();
	Department(string number, string name);
};

class Sc {
public:
	Sc();
	Sc(string sno, string cno, string score);
	void SetSno(string sno);
	string GetSno();
	void SetCno(string cno);
	string GetCno();
	void SetScore(string score);
	string GetScore();
protected:
	string sno;
	string cno;
	string score;
};

class Compare {
public:
	bool operator()(Department t1, Department t2) const{
		return t1.GetNumber().compare(t2.GetNumber()) < 0;
	}
	bool operator()(Person t1, Person t2) const {
		return t1.GetNumber().compare(t2.GetNumber()) < 0;
	}
	bool operator()(Course t1, Course t2) const {
		return t1.GetNumber().compare(t2.GetNumber()) < 0;
	}
	bool operator()(Sc t1, Sc t2) const {
		return t1.GetCno().compare(t2.GetCno()) < 0;
	}
};

        其次设计一个MySQL操作类,用于封装MySQL的连接、SQL语句的执行和数据的存取。

/* 
    databaseManager.h

    by 打印两年半的HelloWorld
*/

#pragma once
#include<mysql.h>
#include<vector>
#include<set>
#include<map>
#include<fstream>
#include"table.h"
using namespace std;
class DatabaseManage {
public:
	DatabaseManage();
	//连接数据库
	bool Connect(const char* server, const char* user, const char* password, const char* database, const char* charset = "gbk");
	//log
	void log(string content);
	//执行SQL语句
	bool ExeSql(string sql);
	//获取数据库所有表
	map<string, bool> GetTables();
	//初始化表
	void InitializeTbs();
	//创建部门表
	void CreateDepartmentTb();
	set<Department, Compare> GetDepartmentTb(string sqlStr= "select * from department;");
	//创建教师&学生表
	void CreatePersonTb(int mode);
	set<Person, Compare> GetPersonTb(string sqlStr);
	//创建课程表
	void CreateCourseTb();
	set<Course, Compare> GetCourseTb(string sqlStr="select *form course;");
	//创建选课表
	void CreateScTb();
	set<Sc, Compare> GetScTb(string sqlStr);
	MYSQL mydata;
	MYSQL_RES* result;//结果集
};

        然后设计Console类,用于设计系统逻辑和界面

/* 
    table.h

    by 打印两年半的HelloWorld
*/

#pragma once
#include<iostream>
#include<string>
#include<vector>
#include<set>
#include<conio.h>
#include<windows.h>
#include<io.h>
#include"databaseManager.h"
using namespace std;
class Console {
public:
	Console();
	bool ConnectDatabase();
	void WriteRecord();
	void SetCursor(int x, int y, bool visible=false);
	void ArrowsMove(int x, int y, int low, int high, vector<char> operand = {});
	void Input(string& str);
	bool Alert(string content);
	void LoadinPage();
	void Control();
	bool SignIn();
	void MainPage();
	void InfoPage(string title, string no="", string name="", string sex="", string age="", string dname="", string password="");
	Department ChoiceDepartment();
	void AddTeacherInfo();
	void DeleteTeacherInfo();
	void Config();
	void ManageStudent();
	void ManageCourse();
	void ChoiceCourse();
	void AddStudentInfo();
	void SearchStudentInfo();
	void ModifyStudentInfo(Person& p);
	void DeleteStudentInfo(Person& p);
	Person ChoiceTeacher();
	void CourseInfoPage(string title,string cno="",string name="",string tname="");
	void AddCourseInfo();
	void ShowCourseAllStudent(Course& c);
	void DeleteStudentCourse(Person& p, Course& c);
	void DeleteCourse(Course& c);
	COORD pos;
	CONSOLE_CURSOR_INFO cci;
	char operand;//操作符
	string account;
	string password;
	int mode=1;
	DatabaseManage data;
	string server= "localhost";
	string user = "root"; //连接数据库的账号
	string Dpassword = "123456"; //连接数据库的密码
	string database = "edu"; //需要操作的数据库
	string charset = "GBK";
	char sqlStr[1024];
	string type[2] = { "教职工","学生" };
	set<Person, Compare> st;
	set<Person, Compare> te;
	set<Department, Compare> de;
	set<Course, Compare> co;
	set<Sc, Compare> sc;
};

        最后编写主函数创建console对象即可

/* 
    main.cpp

    by 打印两年半的HelloWorld
*/

#include"console.h"
int main() {
	Console u;
	return 0;
}

        具体实现代码比较多就不贴了,有需要的可以在 https://github.com/hihinim/-C-MySQL-.git 上下载全部源码,由于楼主是初学者,代码可能存在bug,或者有需要优化的地方,如果还有其他问题也可以参考另一篇文章【记录一下VS2019连接MySQL的过程 - CSDN App】http://t.csdnimg.cn/3fjPH


最终效果图:

086ff1334fcd5f50d3e9bb2d58d0446c.png

242d5cefe9f94d9872f60d8794835135.png

0e519b43dbabf805276e5c4415a562e8.png

 

 

 

 

  • 4
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C MySQL教务管理系统是一款基于C语言和MySQL数据库开发的教务管理系统。该系统的主要功能包括学生信息管理、课程管理、成绩管理以及教师信息管理等。 学生信息管理模块包括学生的基本信息录入、查询和修改功能,可以方便地查看学生的个人信息和学籍信息。课程管理模块用于录入和管理各门课程的信息,包括课程名称、课程编号、授课教师等。成绩管理模块提供成绩录入和查询功能,可以方便地查看学生的成绩,并进行成绩的录入和修改。教师信息管理模块用于管理教师的基本信息,包括教师的姓名、性别、职称等。 系统的操作界面简洁直观,方便操作。用户可以通过界面上的菜单选择不同的功能模块,并根据提示进行相关操作。系统通过与MySQL数据库的连接,可以实现数据的存储和查询,确保了数据的安全性和可靠性。 C MySQL教务管理系统具有以下特点:1.采用C语言开发,运行效率高,占用资源少。2.通过MySQL数据库存储数据,数据结构清晰,易于管理和维护。3.界面简洁明了,操作简单方便。4.支持多用户登录,可以同时处理多个用户的操作请求。5.具备数据备份和恢复功能,确保数据的安全性。 总的来说,C MySQL教务管理系统是一款功能完善、操作简便的教务管理系统,能够满足学校的教务管理需求,并提高教务管理工作的效率和准确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值