学生学籍管理系统

学生学籍管理系统一、设计目的学生根据所学的数据库原理与程序设计的知识,能够针对一个小型的数据库管理系统,进行系统的需求分析,系统设计,数据库设计,编码,测试等,完成题目要... 学生学籍管理系统

一、设计目的

学生根据所学的数据库原理与程序设计的知识,能够针对一个小型的数据库管理系统,进行系统的需求分析,系统设计,数据库设计,编码,测试等,完成题目要求的功能,从而达到掌握开发一个小型数据库的目的。

二、设计内容

1. 主要的数据表

学生基本情况数据表,学生成绩数据表,课程表,代码表等。

2. 主要功能模块

1) 实现学生基本情况的录入、修改、删除等基本操作。

2) 对学生基本信息提供灵活的查询方式。

3) 完成一个班级的学期选课功能。

4) 实现学生成绩的录入、修改、删除等基本操作。

5) 能方便的对学生的个学期成绩进行查询。

6) 具有成绩统计、排名等功能。

7) 具有留级、休学等特殊情况的处理功能。

8) 能输出常用的各种报表。

9) 具有数据备份和数据恢复功能。

三、设计要求

学生成绩表的设计,要考虑到不同年级的教学计划的变化情况。

对于新生班级,应该首先进行基本情况录入、选课、然后才能进行成绩录入。
谁能给个参考,用SQL做的,谢谢
展开
 我来答
48111603
2007-12-15
知道答主
回答量:34
采纳率:0%
帮助的人:0
展开全部
基本上满足你的要求你再自己改一下吧!

#include <iostream>
#include <string>
#include<fstream>
#include<iomanip>
using namespace std;
int amount=0; //记录学生个数
ofstream *file[50];
/////////////////////////////////*学生成绩结构体*////////////////////////////////////////
struct score
{
float yw;
float sx;
float yy;
float wl;
float hx;
float sw;
struct score *next;
};
/////////////////////////////////*学生数据类*////////////////////////////////////////
class student
{
public:
string mun;
string name;
score sc1;
score sc2;
score sc3;//平时成绩,期末成绩,总成绩;
class student *next;
};
/////////////////////////////////*函数声明*////////////////////////////////////////
void input(student *head); //录入
void search1(student *head); //姓名查询
void search2(student *head); //学号查询
void change(student *head); //修改
void shanchu(student *head); //删除
void get(student *head); //取数据
void display(); //显示菜单
void show(student *head); //显示数据
void readin(student *head); //保存数据
void chushihua(student *head); //初始化
/////////////////////////////////*主函数*////////////////////////////////////////
void main() //主函数
{
system("color f0");
char x;
bool flag2=0;
student *head=new student; //初始化学生数据
head->next=NULL;
cout<<" ★ 欢迎使用学生信息管理系统 ★ \n ";
display(); //显示菜单
do
{
do
{
cin>>x;
if((x>='0'&&x<='8'))
flag2=1;
else
{
cout<<"指令错误!!!!!!!!!!"<<endl;
cout<<" 请选择相应的数字进行操作: ";
}
}while(flag2==0);
switch(x)
{
case '0':cout<<"******************************现在进行学生信息录入******************************\n";
input(head);
cout<<"输入的学生信息为:\n";
show(head);
cout<<"********************************************************************************\n";
display(); break;
case '1':
{
char z;
cout<<"******************************现在进行学生信息查询******************************\n";
cout<<"请选择查询方式:";
cout<<"(0).姓名查询;(1).学号查询:"; cin>>z;
while(z!='0'&&z!='1')
{
cout<<"指令错误<请选择(0)或者(1)!>!!!!!!!"<<endl;
cout<<"请选择查询方式:(0).姓名查询;(1).学号查询:"; cin>>z;
}
switch(z)
{
case '0': search1(head);break;//按姓名查询
case '1': search2(head);break;//按学号查询
}
cout<<"********************************************************************************\n";
display();
break;
}
case '2': cout<<"******************************现在进行学生信息修改******************************\n";
change(head);
cout<<"********************************************************************************\n";
display(); break; //按姓名修改
case '3': cout<<"******************************现在进行学生信息删除******************************\n";
shanchu(head);
show(head);
cout<<"********************************************************************************\n";
display();
break; //删除
case '4': cout<<"******************************现在进行显示学生信息******************************\n";
show(head);
cout<<"********************************************************************************\n";
display();
break; //显示数据
case '5':cout<<"******************************现在进行初始化学生信息****************************\n";
chushihua(head);
cout<<"********************************************************************************\n";
display() ;
break;
case '6':cout<<"******************************现在进行提取学生信息******************************\n";
get(head);
cout<<"********************************************************************************\n";
display(); break;
case '7':cout<<"******************************现在进行保存学生信息******************************\n";
readin(head);
cout<<"********************************************************************************\n";
display();
break;
case '8':
cout<<"********************************************************************************\n";
cout<<" ¤ 您已退出学生信息管理系统, 谢谢您的使用! ¤ \n";
cout<<"********************************************************************************\n";
cout<<endl;
exit(0);
break;
}
}while(flag2==1);
}
/////////////////////////////////*显示菜单*////////////////////////////////////////
void display()
{
cout<<" ++++++++++**********++++++++++**********++++++++++\n";
cout<<" $ 菜 单 $\n";
cout<<" $ ^^^^^^^^^^ $\n";
cout<<" $ 请选择: $\n";
cout<<" $ [0]-录入; [1]-查询; [2]-修改; $\n";
cout<<" $ [3]-删除; [4]-显示; [5]-初始化; $\n";
cout<<" $ [6]-提取; [7]-保存; [8]-退出; $\n";
cout<<" **********++++++++++**********++++++++++**********\n";
cout<<" 请选择相应的数字进行操作: ";
}
/////////////////////////////////*初始化学生数据*////////////////////////////////////////
void chushihua(student *head)
{
int j=0;char c;
cout<<"注意:初始化操作将删除<总评成绩.txt>文件中的所有信息!!!!!!\n";
cout<<"是否继续操作?(y/n):";cin>>c;
if (c='y')
{
amount=1;
file[j]=new ofstream("F:\\课设\\总评成绩.txt",ios::out);
}
cout<<"......成功清除<总评成绩.txt>的信息\n ";
}
/////////////////////////////////*显示学生数据*////////////////////////////////////////
void show(student *head)
{
student *stu=head;
cout<<"| 学号 | 姓名 | 语文 | 数学 | 英语 | 物理 | 化学 | 生物 |"<<endl;
while(stu->next!=NULL)
{
(*stu).sc3.yw=((*stu).sc1.yw)*0.30+((*stu).sc2.yw)*0.70;//总成绩计算
(*stu).sc3.sx=((*stu).sc1.sx)*0.30+((*stu).sc2.sx)*0.70;
(*stu).sc3.yy=((*stu).sc1.yy)*0.30+((*stu).sc2.yy)*0.70;
(*stu).sc3.wl=((*stu).sc1.wl)*0.30+((*stu).sc2.wl)*0.70;
(*stu).sc3.hx=((*stu).sc1.hx)*0.30+((*stu).sc2.hx)*0.70;
(*stu).sc3.sw=((*stu).sc1.sw)*0.30+((*stu).sc2.sw)*0.70;

stu=stu->next;
cout<<"| "<<setw(9)<<(*stu).mun;
cout<<" | "<<setw(6)<<(*stu).name;
cout<<" | "<<setw(4)<<(*stu).sc3.yw;
cout<<" | "<<setw(4)<<(*stu).sc3.sx;
cout<<" | "<<setw(4)<<(*stu).sc3.yy;
cout<<" | "<<setw(4)<<(*stu).sc3.wl;
cout<<" | "<<setw(4)<<(*stu).sc3.hx;
cout<<" | "<<setw(4)<<(*stu).sc3.sw;
cout<<" | "<<endl;
}
}
/////////////////////////////////*保存学生数据*////////////////////////////////////////
void readin(student *head)
{
char a;
student *stu=head->next;
cout<<"现在保存输入学生数据,是否继续操作?(y/n)";
cin>>a;
ofstream outfile("F:\\课设\\总评成绩.txt",ios::out);
if(! outfile)
{
cout<<"打开文件错误!!!!!!!\n";
exit(0);
}
while(a!='n')
{
while(stu!=NULL)
{ outfile<<"************************第"<<amount<<"个学生的数据:*************************\n";
outfile<<"| 学号 | 姓名 | 语文 | 数学 | 英语 | 物理 | 化学 | 生物 |"<<endl;
outfile<<" 平时成绩: \n"
<<"| "<<setw(9)<<(*stu).mun<<" | "<<setw(6)<<(*stu).name<<" | "<<setw(4)<<(*stu).sc1.yw<<
" | "<<setw(4)<<(*stu).sc1.sx<<" | "<<setw(4)<<(*stu).sc1.yy<<" | "<<setw(4)<<(*stu).sc1.wl
<<" | "<<setw(4)<<(*stu).sc1.hx<<" | "<<setw(4)<<(*stu).sc1.sw<<endl;
outfile<<" 期末成绩: \n"
<<"| "<<setw(9)<<(*stu).mun<<" | "<<setw(6)<<(*stu).name<<" | "<<setw(4)<<(*stu).sc2.yw<<
" | "<<setw(4)<<(*stu).sc2.sx<<" | "<<setw(4)<<(*stu).sc2.yy<<" | "<<setw(4)<<(*stu).sc2.wl
<<" | "<<setw(4)<<(*stu).sc2.hx<<" | "<<setw(4)<<(*stu).sc2.sw<<endl;
outfile<<" 总评成绩: \n"
<<"| "<<setw(9)<<(*stu).mun<<" | "<<setw(6)<<(*stu).name<<" | "<<setw(4)<<(*stu).sc3.yw<<
" | "<<setw(4)<<(*stu).sc3.sx<<" | "<<setw(4)<<(*stu).sc3.yy<<" | "<<setw(4)<<(*stu).sc3.wl
<<" | "<<setw(4)<<(*stu).sc3.hx<<" | "<<setw(4)<<(*stu).sc3.sw<<endl;
amount++;
stu=stu->next;
}
break;
}
cout<<"......成功将学生数据保存到<总评成绩.txt>中! ";
outfile.close();
}
/////////////////////////////////*录入学生数据*////////////////////////////////////////
void input(student *head)
{
char c;
int j=0;
student *p=head;
file[j]=new ofstream("F:\\课设\\总评成绩.txt",ios::app);
do
{
student *stu=new student;
cout<<"请输入学号(9位数字):"<<setw(9); cin>>(*stu).mun;
cout<<"请输入姓名:"<<setw(20); cin>>(*stu).name;
cout<<"请输入语文成绩(平时成绩和期末成绩):"<<setw(2);
cin>>(*stu).sc1.yw>>(*stu).sc2.yw;
cout<<"请输入数学成绩(平时成绩和期末成绩):"<<setw(2);
cin>>(*stu).sc1.sx>>(*stu).sc2.sx;
cout<<"请输入英语成绩(平时成绩和期末成绩):"<<setw(2);
cin>>(*stu).sc1.yy>>(*stu).sc2.yy;
cout<<"请输入物理成绩(平时成绩和期末成绩):"<<setw(2);
cin>>(*stu).sc1.wl>>(*stu).sc2.wl;
cout<<"请输入化学成绩(平时成绩和期末成绩):"<<setw(2);
cin>>(*stu).sc1.hx>>(*stu).sc2.hx;
cout<<"请输入生物成绩(平时成绩和期末成绩):"<<setw(2);
cin>>(*stu).sc1.sw>>(*stu).sc2.sw;
(*stu).sc3.yw=((*stu).sc1.yw)*0.30+((*stu).sc2.yw)*0.70;//总成绩计算
(*stu).sc3.sx=((*stu).sc1.sx)*0.30+((*stu).sc2.sx)*0.70;
(*stu).sc3.yy=((*stu).sc1.yy)*0.30+((*stu).sc2.yy)*0.70;
(*stu).sc3.wl=((*stu).sc1.wl)*0.30+((*stu).sc2.wl)*0.70;
(*stu).sc3.hx=((*stu).sc1.hx)*0.30+((*stu).sc2.hx)*0.70;
(*stu).sc3.sw=((*stu).sc1.sw)*0.30+((*stu).sc2.sw)*0.70;
stu->next=p->next;
p->next=stu;
amount++;
cout<<"数据录入成功,想继续录入吗(y/n)"; cin>>c;
p=p->next;
while(c!='y'&&c!='n')
{
cout<<"指令错误<请输入y/n!>!!!!!!"<<endl;
cout<<"数据录入成功,想继续录入吗(y/n)";
cin>>c;
}
}while(c=='y');
j++;
cout<<"输入了 "<<amount<<"个学生的信息."<<endl;
}
/////////////////////////////////*使用姓名查询学生数据*////////////////////////////////////////
void search1(student *head)//姓名查询
{
char c;
string name;
do
{
student *stu=head->next;
bool flag=0;
cout<<"请输入你要查询的学生姓名:";
cin>>name;
do{
if(stu!=NULL&&name==(*stu).name) //输出总成绩
{
flag=1;
cout<<"您要查询的学生是:"<<stu->name<<endl;
cout<<"| 学号 | 姓名 | 语文 | 数学 | 英语 | 物理 | 化学 | 生物 |"<<endl;
cout<<"| "<<setw(9)<<(*stu).mun;
cout<<" | "<<setw(6)<<(*stu).name;
cout<<" | "<<setw(4)<<(*stu).sc3.yw;
cout<<" | "<<setw(4)<<(*stu).sc3.sx;
cout<<" | "<<setw(4)<<(*stu).sc3.yy;
cout<<" | "<<setw(4)<<(*stu).sc3.wl;
cout<<" | "<<setw(4)<<(*stu).sc3.hx;
cout<<" | "<<setw(4)<<(*stu).sc3.sw;
cout<<" | "<<endl;
}
stu=stu->next;
}while(stu!=NULL);
if(flag==0)
cout<<"对不起!您要查询的学生不存在!!!!!!!"<<endl;
cout<<"您想继续查询吗?(y/n)"; cin>>c;
while(c!='y'&&c!='n')
{
cout<<"指令错误<请输入y/n!>!!!!!!!"<<endl;
cout<<"您想继续查询吗?(y/n)"; cin>>c;
}
} while(c=='y');
}
/////////////////////////////////*用学号查询学生数据*////////////////////////////////////////
void search2(student *head)//学号查询
{
char c;string no;
do
{
student *stu=head->next;
int flag=0;
cout<<"请输入你要查询的学生学号:";
cin>>no;
do
{
if(stu!=NULL&&no==(*stu).mun)
{
flag=1;
cout<<"您要查询的学生是:"<<stu->name<<endl;
cout<<"| 学号 | 姓名 | 语文 | 数学 | 英语 | 物理 | 化学 | 生物 |"<<endl;
cout<<"| "<<setw(9)<<(*stu).mun;
cout<<" | "<<setw(6)<<(*stu).name;
cout<<" | "<<setw(4)<<(*stu).sc3.yw;
cout<<" | "<<setw(4)<<(*stu).sc3.sx;
cout<<" | "<<setw(4)<<(*stu).sc3.yy;
cout<<" | "<<setw(4)<<(*stu).sc3.wl;
cout<<" | "<<setw(4)<<(*stu).sc3.hx;
cout<<" | "<<setw(4)<<(*stu).sc3.sw;
cout<<" | "<<endl;
}
stu=stu->next;
}while(stu!=NULL);
if(flag==0)
cout<<"对不起!您要查询的学生不存在!!!!!!!"<<endl;
cout<<"您想继续查询吗?(y/n)";
cin>>c;
while(c!='y'&&c!='n')
{
cout<<"指令错误<请输入y/n!>!!!!!!!"<<endl;
cout<<"您想继续查询吗?(y/n)"<<endl;
cin>>c;
}
}while(c=='y');
}
/////////////////////////////////*修改学生数据*////////////////////////////////////////
void change(student *head)
{
string name; char c;
do
{
bool flag2=0;
student *stu=head ;
score sc1;
score sc2;
score sc3;
cout<<"请输入您要修改的学生的姓名:";
cin>>name;
do
{
if(name==(*stu).name)
{
flag2=1;
cout<<"请输入新的.语文.成绩(平时成绩和期末成绩):";
cin>>sc1.yw>>sc2.yw;
cout<<"请输入新的.数学.成绩(平时成绩和期末成绩):";
cin>>sc1.sx>>sc2.sx;
cout<<"请输入新的.英语.成绩(平时成绩和期末成绩):";
cin>>sc1.yy>>sc2.yy;
cout<<"请输入新的.物理.成绩(平时成绩和期末成绩):";
cin>>sc1.wl>>sc2.wl;
cout<<"请输入新的.化学.成绩(平时成绩和期末成绩):";
cin>>sc1.hx>>sc2.hx;
cout<<"请输入新的.生物.成绩(平时成绩和期末成绩):";
cin>>sc1.sw>>sc2.sw;
sc3.yw=sc1.yw*0.30+sc2.yw*0.70;//总成绩计算
sc3.sx=sc1.sx*0.30+sc2.sx*0.70;
sc3.yy=sc1.yy*0.30+sc2.yy*0.70;
sc3.wl=sc1.wl*0.30+sc2.wl*0.70;
sc3.hx=sc1.hx*0.30+sc2.hx*0.70;
sc3.sw=sc1.sw*0.30+sc2.sw*0.70;
(*stu).sc3.yw=sc3.yw;
(*stu).sc3.sx=sc3.sx;
(*stu).sc3.yy=sc3.yy;
(*stu).sc3.wl=sc3.wl;
(*stu).sc3.hx=sc3.hx;
(*stu).sc3.sw=sc3.sw;
cout<<"| 学号 | 姓名 | 语文 | 数学 | 英语 | 物理 | 化学 | 生物 |"<<endl;
cout<<"| "<<setw(9)<<(*stu).mun;
cout<<" | "<<setw(6)<<(*stu).name;
cout<<" | "<<setw(4)<<(*stu).sc3.yw;
cout<<" | "<<setw(4)<<(*stu).sc3.sx;
cout<<" | "<<setw(4)<<(*stu).sc3.yy;
cout<<" | "<<setw(4)<<(*stu).sc3.wl;
cout<<" | "<<setw(4)<<(*stu).sc3.hx;
cout<<" | "<<setw(4)<<(*stu).sc3.sw;
cout<<" | "<<endl;
cout<<".......数据修改成功!\n";
break;
}
stu=stu->next;
}while(stu!=NULL);
if(flag2==0)
{
cout<<"对不起!您要修改的学生不存在!请检查重新输入!!!!!!!"<<endl;
}
cout<<"想继续修改吗?(y/n)";
cin>>c;
if(c!='y'&&c!='n')
{
cout<<"指令错误!请重新输入<y/n>!!!!!!!";
cin>>c;
}
}while(c=='y');

}
/////////////////////////////////*删除学生数据*////////////////////////////////////////
void shanchu(student *head)//学号
{
char c;string no;
do
{
int flag=0;
cout<<"请输入你要删除的学生学号:";
cin>>no;

student *q,*p;
q=head;
while(q->next!=NULL&&q->next->mun!=no)
q=q->next;
if(q->next!=NULL)
{
flag=1;
p=q->next;
q->next=q->next->next;
amount--;
free(p);
cout<<"......成功删除! ";
}
if(flag==0)
cout<<"对不起!您要删除的学生不存在!!!!!!!"<<endl;
cout<<"您想继续删除吗?(y/n)";
cin>>c;
while(c!='y'&&c!='n')
{
cout<<"指令错误<请输入y/n!>!!!!!!!"<<endl;
cout<<"您想继续删除吗?(y/n)";
cin>>c;
}
}while(c=='y');
}
/////////////////////////////////*提取学生数据*////////////////////////////////////////
void get(student *head)
{
student *p;
p=head;
int j=0;
string no;
cout<<"请输入您想提取的入学年份+在读年级+在读班级的编号(7位数字):";
cin>>no;
while(p->next!=NULL)
{
if(no==(p->next->mun).substr(0,7))
{
cout<<"管理系统有您要提取的信息!"<<endl;
j=1;
}
else p=p->next;
if(j==1)
break;
}
if(j==1)
{
int c,m=0;
string b,b1,e,subject[6]={"yuwen","shuxue","yinyu","wuli","huaxue","shengwu"};
string kemu[6]={"语文","数学","英语","物理","化学","生物"};
cout<<"输入您想提取的科目代码:"<<endl;
cout<<"1-->语文 2-->数学 3-->英语"<<endl;
cout<<"4-->物理 5-->化学 6-->生物"<<endl;
cout<<"选择:"; cin>>c;
string cla="class";
e=no.substr(6,1);
b1=cla+e;
b=b1+subject[c-1];
char *f=new char[20];
for(int i=0;i<20;i++)
f[i]=b[i];
f=strcat(f,".txt");
ofstream outfile(f,ios::out);
if(! outfile)
{
cout<<"打开错误!!!!!!!"<<endl;
exit(1);
}
outfile<<"\t您要提取的信息\t\t\t"<<endl;
outfile<<" -----------------------------"<<endl;
outfile<<"| 学号 | 姓名 | ";
outfile<<kemu[c-1]<<" |"<<endl;
while(p->next!=NULL)
{
outfile<<" -----------------------------"<<endl;
outfile<<"|"<<setw(11)<<p->next->mun<<" | "<<setw(6)<<p->next->name<<" |";
switch(c)
{
case 1:outfile<<setw(5)<<p->next->sc3.yw<<" |";
outfile<<endl;
break;
case 2:outfile<<setw(5)<<p->next->sc3.sx<<" |";
outfile<<endl;
break;
case 3:outfile<<setw(5)<<p->next->sc3.yy<<" |";
outfile<<endl;
break;
case 4:outfile<<setw(5)<<p->next->sc3.wl<<" |";
outfile<<endl;
break;
case 5:outfile<<setw(5)<<p->next->sc3.hx<<" |";
outfile<<endl;
break;
case 6:outfile<<setw(5)<<p->next->sc3.sw<<" |";
outfile<<endl;
break;
}
p=p->next;
}
outfile<<" -----------------------------"<<endl;
outfile.close();
cout<<"......已经保存在"<<f<<"文本文档中!"<<endl;
}
if(j==0)
cout<<"管理系统中没有您要提取的班级数据!!!!!!!!"<<endl;
}
深圳市校管家教育科技有限公司_
2024-02-23 广告
选择培训学校管理系统,需要考虑多方面因素,如系统功能。培训学校管理系统实现了动态的网络化管理,提高了各职能部门的协同办公效能。培训学校管理系统是针对培训学校的管理和教学特点而设计的高效协同工作平台和优秀的综合管理系统。具体费用不是一定的,和... 点击进入详情页
本回答由深圳市校管家教育科技有限公司_提供
mlpmlp0303
2007-12-06
知道答主
回答量:72
采纳率:0%
帮助的人:37.1万
展开全部
自己去网上找啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式