学生成绩系统数据库代码(学生成绩查询代码)
admin 发布:2022-12-19 04:53 144
今天给各位分享学生成绩系统数据库代码的知识,其中也会对学生成绩查询代码进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
c语言程序学生成绩管理系统源代码
头文件:::
#ifndef H_STUDENT_HH
#define H_STUDENT_HH
#include "stdio.h"
#include "string.h"
#include "malloc.h"
#define LEN sizeof(struct message_student) /*一个结构体数组元素的长度*/
#define numsubs 5 /*学科数目*/
typedef struct message_student /*结构体定义*/
{
char number[6];
char name[20];
char sex[4];
float subject[numsubs];
float score;
float average;
int index;
}student;
extern int numstus; /*学生数目*/
extern student *pointer; /*指向结构体数组*/
extern int lens;
int menu_select(); /*函数声明*/
int openfile(student stu[]);
int findrecord(student stud[]);
int writetotext(student stud[]);
void welcome();
void display1();
void showtable();
void sort(student stu[]);
void deleterecord(student stu[],int i);
void addrecord(student stud[]);
void display(student stud[],int n1,int n2);
void amendrecord(student stud[]);
void count(student stud[]);
void sortnum(student stud[]);
void sortnum2(student stud[]);
void sortname(student stud[]);
void sortname2(student stud[]);
void sortcount(student stud[]);
void sortcount2(student stud[]);
void statistic(student stud[]);
void display1();
#endif
#include "head.h"
int menu_select()
{
char c;
printf("\n\n");
printf(" | 1. 增加学生记录 5.统计信息 |\n");
printf(" | 2. 查询学生记录 6.打开文件 |\n");
printf(" | 3. 修改学生记录 7.保存文件 |\n");
printf(" | 4. 学生纪录排序 8.显示记录 |\n");
printf(" | 0.退出系统 |\n");
printf("\n\n");
printf("请选择(0-8):");
c=getchar();
getchar();
return (c-'0');
}
#include "head.h"
int findrecord(student stud[]) /*查找信息*/
{
char str[2];
int i,num;
if(numstus==0)
{
printf("没有可被查找的记录\n");
return -1;
}
else
{
printf("以何种方式查找?\n1.学号\t2.姓名\t3.名次\n");
gets(str);
if(str[0]=='1') /*按学号查找*/
{
printf("请输入学号:");
gets(str);
for(i=0;i=numstus;i++)
if(strcmp(str,stud[i].number)==0)
{
display(stud,i,i);
break;
}
else continue;
}
else if(str[0]=='2') /*按姓名查找*/
{
printf("请输入姓名:");
gets(str);
for(i=0;i=numstus;i++)
if(strcmp(str,stud[i].name)==0)
{
display(stud,i,i);
break;
}
else continue;
}
else if(str[0]=='3') /*按名次查找*/
{
printf("请输入名次:");
scanf("%d",num);
getchar();
for(i=0;i=numstus;i++)
if(num==stud[i].index)
{
display(stud,i,i);
break;
}
else continue;
}
if(inumstus)
{
printf("没有查找所要的信息。\n");
return -1;
}
return i;
}
}
#include"head.h"
int openfile(student stu[])
{
int i=0,j;
FILE *fp;
char filename[20],str[2];
if(numstus!=0)
{
printf("已经有记录存在,是否保存?(y/n)");
gets(str);
if(str[0]=='y'||str[0]=='Y')
writetotext(stu);
}
printf("请输入文件名:");
gets(filename);
numstus=0;
if((fp=fopen(filename,"rb+"))==NULL)
{
printf("无法打开该文件\n");
return(-1);
}
fscanf(fp,"%d",numstus);
fgetc(fp);
while(inumstus)
{
fscanf(fp,"%s",stu[i].number);
fscanf(fp,"%s",stu[i].name);
fscanf(fp,"%s",stu[i].sex);
for(j=0;jnumsubs;j++)
fscanf(fp,"%f",stu[i].subject[j]);
fscanf(fp,"%f",stu[i].score);
fscanf(fp,"%f",stu[i].average);
fscanf(fp,"%d",stu[i].index);
i++;
}
fclose(fp);
printf("文件读取成功\n");
printf("是否显示纪录?(y/n)");
gets(str);
if(str[0]=='y'||str[0]=='Y')
display(stu,0,numstus-1);
return(0);
}
#include "head.h"
void sort(student stud[])
{
int i,j=0;
char str[5];
student *p;
p=stud;
if(numstus==0)
{
printf("没有可供查询的记录!");
}
while(1)
{
for(i=0;;i++)
{
printf(" 请输入查询方式:");
printf("(直接输入回车则结束查询操作)\n");
printf("1.按照学号\t");
printf("2.按照姓名\t");
printf("3.按照名次\n");
gets(str);
if(strlen(str)==0) break;
if(str[0]=='1')
{
printf("请输入排序次序:\n");
printf("1.升序排列\t");
printf("2.降序排列\n");
gets(str);
if(str[0]=='1')
sortnum2(p);
else
sortnum(p);
display(stud,0,numstus-1);
}
else if(str[0]=='2')
{
printf("请输入排序次序:\n");
printf("1.升序排列\t");
printf("2.降序排列\n");
gets(str);
if(str[0]=='1')
sortname2(p);
else
sortname(p);
display(stud,0,numstus-1);
}
else if(str[0]=='3')
{
printf("请输入排序次序:\n");
printf("1.升序排列\t");
printf("2.降序排列\n");
gets(str);
if(str[0]=='1')
sortcount2(p);
else
sortcount(p);
display(stud,0,numstus-1);
}
else printf("请输入1~3");
printf("是否退出排序?(y/n)");
gets(str);
if(str[0]=='y'||str[0]=='Y') break;
}
return;
}
}
void sortnum(student stud[])
{
int i,j;
student temp;
student *p;
p=stud;
for(i=0;inumstus;i++)
for(j=0;jnumstus-i-1;j++)
{
if(strcmp(stud[j+1].number,stud[j].number)0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortnum2(student stud[])
{
int i,j;
student temp;
student *p;
p=stud;
for(i=0;inumstus;i++)
for(j=0;jnumstus-i-1;j++)
{
if(strcmp(stud[j].number,stud[j+1].number)0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortname(student stud[])
{
int i,j;
student temp;
student *p;
p=stud;
for(i=0;inumstus;i++)
for(j=0;jnumstus-i-1;j++)
{
if(strcmp(stud[j+1].name,stud[j].name)0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortname2(student stud[])
{
int i,j;
student temp;
student *p;
p=stud;
for(i=0;inumstus;i++)
for(j=0;jnumstus-i-1;j++)
{
if(strcmp(stud[j].name,stud[j+1].name)0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortcount(student stud[])
{
int i,j;
student temp;
student *p;
p=stud;
for(i=0;inumstus;i++)
for(j=0;jnumstus-i-1;j++)
{
if(stud[j+1].indexstud[j].index)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortcount2(student stud[])
{
int i,j;
student temp;
student *p;
p=stud;
for(i=0;inumstus;i++)
for(j=0;jnumstus-i-1;j++)
{
if(stud[j].indexstud[j+1].index)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
#include"head.h"
void statistic(student stud[]) /*新增功能,输出统计信息*/
{
int i,j=0,k=0;
char c1,str[2];
float average[numsubs],sum=0;
if(numstus==0)
printf("没有可被查找的记录\n");
else
{
while(1)
{
printf("下面将统计考试成绩\n");
printf("请选择你要统计哪科的成绩 1.A\t2.B\t3.C\t4.D\t5.E\n");
c1=getchar();
printf("\t一共有个%d记录\n",numstus); /*总共记录数*/
switch(c1)
{
case '1':
for(i=0;inumstus;i++) /*循环输入判断*/
{
sum+=stud[i].subject[0];
if(stud[k].subject[0]stud[i].subject[0]) k=i;
if(stud[j].subject[0]stud[i].subject[0]) j=i;
}
average[0]=sum/numstus;
printf("\t科目A的最高分:\n"); /*最高分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[j].number,stud[j].name,stud[j].subject[0]);
printf("\t科目A的最低分是:\n"); /*最低分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[k].number,stud[k].name,stud[k].subject[0]);
printf("\t科目A的平均分是 %5.2f\n",average[0]); /*平均分*/
break;
case '2':
for(i=0;inumstus;i++) /*循环输入判断*/
{
sum+=stud[i].subject[1];
if(stud[k].subject[1]stud[i].subject[1]) k=i;
if(stud[j].subject[1]stud[i].subject[1]) j=i;
}
average[1]=sum/numstus;
printf("\t科目B的最高分:\n"); /*最高分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[j].number,stud[j].name,stud[j].subject[1]);
printf("\t科目B的最低分是:\n"); /*最低分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[k].number,stud[k].name,stud[k].subject[1]);
printf("\t科目B的平均分是 %5.2f\n",average[1]); /*平均分*/
break;
case '3':
for(i=0;inumstus;i++) /*循环输入判断*/
{
sum+=stud[i].subject[2];
if(stud[k].subject[2]stud[i].subject[2]) k=i;
if(stud[j].subject[2]stud[i].subject[2]) j=i;
}
average[2]=sum/numstus;
printf("\t科目C的最高分:\n"); /*最高分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[j].number,stud[j].name,stud[j].subject[2]);
printf("\t科目C的最低分是:\n"); /*最低分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[k].number,stud[k].name,stud[k].subject[2]);
printf("\t科目C的平均分是 %5.2f\n",average[2]); /*平均分*/
break;
case '4':
for(i=0;inumstus;i++) /*循环输入判断*/
{
sum+=stud[i].subject[3];
if(stud[k].subject[3]stud[i].subject[3]) k=i;
if(stud[j].subject[3]stud[i].subject[3]) j=i;
}
average[3]=sum/numstus;
printf("\t科目D的最高分:\n"); /*最高分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[j].number,stud[j].name,stud[j].subject[3]);
printf("\t科目D的最低分是:\n"); /*最低分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[k].number,stud[k].name,stud[k].subject[3]);
printf("\t科目D的平均分是 %5.2f\n",average[3]); /*平均分*/
break;
case '5':
for(i=0;inumstus;i++) /*循环输入判断*/
{
sum+=stud[i].subject[4];
if(stud[k].subject[4]stud[i].subject[4]) k=i;
if(stud[j].subject[4]stud[i].subject[4]) j=i;
}
average[4]=sum/numstus;
printf("\t科目E的最高分:\n"); /*最高分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[j].number,stud[j].name,stud[j].subject[4]);
printf("\t科目E的最低分是:\n"); /*最低分*/
printf("\t\t学号:%s 姓名:%s 分数:%.2f\n",stud[k].number,stud[k].name,stud[k].subject[4]);
printf("\t科目E的平均分是 %5.2f\n",average[4]); /*平均分*/
break;
default:printf("输入错误!请输入1~5之间的数\n");
}
sum=0;
getchar();
printf("是否继续进行统计?(y/n)");
gets(str);
if(str[0]=='y'||str[0]=='Y') ;
else break;
}
}
}
#include"head.h"
int writetotext(student stud[]) /*将所有记录写入文件*/
{
int i=0,j;
FILE *fp;
char filename[20];
printf("输入文件名称:");
gets(filename);
fp=fopen(filename,"w");
fprintf(fp,"%d\n",numstus);
while(inumstus)
{
fprintf(fp,"%s %s %s ",stud[i].number,stud[i].name,stud[i].sex);
for(j=0;jnumsubs;j++)
fprintf(fp,"%f ",stud[i].subject[j]);
fprintf(fp,"%f %f %d ",stud[i].score,stud[i].average,stud[i].index);
i++;
}
fclose(fp);
printf("已成功存储!\n");
display(stud,0,numstus-1);
numstus=0;
return 0;
}
#include"head.h"
void welcome()
{
printf("\t*************************************************************\n");
printf("\t\t\t\t这是一个学生成绩管理系统\n\t\t\t\t 倾情奉献 欢迎使用!\n");
printf("\t*************************************************************\n");
}
void showtable()
{
printf("---------------------------------------------------------------------------------------\n");
printf("学号\t姓名\t性别\tA\tB\tC\tD\tE\t总分\t平均分\t名次\n");
printf("---------------------------------------------------------------------------------------\n");
}
void display(student stud[],int n1,int n2)
{
int i;
showtable(); /*显示表头*/
for(i=n1;i=n2;i++)
printf("%s\t%s\t%s\t%.2f\t%.2f\t%.2f\t%.2f\t%.2f\t%.2f\t%.2f\t%d\t\n",stud[i].number,stud[i].name,stud[i].sex,stud[i].subject[0],stud[i].subject[1],stud[i].subject[2],stud[i].subject[3],stud[i].subject[4],stud[i].score,stud[i].average,stud[i].index);
/*通过循环输出数据*/
}
void display1()
{
printf("\t\t本系统由计应精英一组亲情制作\n\n");
printf("\t\t制作人员列表: (按比划)\n");
printf("\t\t王庆斌\t\t\t张威\n\t\t李智\t\t\t周在峰\n\t\t杨凯\t\t\t胡杨\n");
printf("\n\n");
getchar();
}
#include"head.h"
#includestring.h
void amendrecord(student stud[])
{
char str[5]; /*供用户输入*/
int i=-1,j;
if(numstus==0) /*没有记录返回*/
printf("没有可供修改的记录!");
while(i0)
{
i=findrecord(stud);
if(i=0)
{
printf("要删除这个学生的信息吗?(y/n)");
gets(str);
if(str[0]=='y'||str[0]=='Y')
{
deleterecord(stud,i);
count(stud);
}
else
{
printf("确定要修改这个学生的信息吗?(y/n)");
gets(str);
if(str[0]=='y'||str[0]=='Y')
{
printf("下面请重新输入学生的信息:\n");
printf("请输入学号:");
gets(stud[i].number);
printf("请输入姓名:");
gets(stud[i].name);
printf("请输入性别(男/女 1/0):");
gets(str);
if(str[0]=='0')
strcpy(stud[i].sex,"女");
else
strcpy(stud[i].sex,"男");
stud[i].score=0;
printf("请按顺序输入成绩:");
for(j=0;jnumsubs;j++)
{
scanf("%f",stud[i].subject[j]);
stud[i].score+=stud[i].subject[j];
}
getchar();
stud[i].average=stud[i].score/numsubs;
}
count(stud);
}
display(stud,0,numstus-1);
}
printf("是否继续进行其他修改?(y/n)\n");
gets(str);
if(str[0]=='y'||str[0]=='Y')
i=-1;
else i=1;
}
}
void deleterecord(student stu[],int i) /*删除信息*/
{
int j;
while(i=0)
{
for(j=i;jnumstus;j++)
stu[j]=stu[j+1];
numstus--;
printf("删除成功!\n");
}
}
void count(student stud[])
{
int i,j;
for(i=0;inumstus;i++)
{
stud[i].index=1;
for(j=0;jnumstus;j++)
if(stud[j].scorestud[i].score)
stud[i].index++;
}
}
#include "head.h"
void addrecord(student stud[])
{
int i=0,j,num;
char str[5];
if(numstus!=0)
{
printf("已有记录存在是否覆盖?(y/n)\n");
gets(str);
if(str[0]=='Y'||str[0]=='y')
i=0;
else i=numstus;
}
printf("请输入增加的学生信息条目数:");
scanf("%d",num);
if(i==0)
numstus=num;
else numstus+=num;
if(numstuslens)
{
lens+=50;
pointer=(student *)realloc(pointer,lens*LEN);
}
printf("请输入学生信息:\n");
for(;inumstus;i++)
{
getchar();
printf("请输入学号:");
gets(pointer[i].number);
printf("请输入姓名:");
gets(pointer[i].name);
printf("请输入性别(男/女 1/0):");
gets(pointer[i].sex);
if(pointer[i].sex[0]=='0') strcpy(pointer[i].sex,"女");
else strcpy(pointer[i].sex,"男");
printf("请输入各科成绩:(按ABCDE的顺序):");
stud[i].score=0;
for(j=0;jnumsubs;j++)
{
scanf("%f",stud[i].subject[j]); /*计算总分*/
stud[i].score+=stud[i].subject[j];
}
stud[i].average=stud[i].score/numsubs; /*计算平均分*/
}
count(stud); /*附名次*/
display(stud,0,numstus-1);
getchar();
}#include "head.h"
int numstus;
int lens;
student *pointer;
void main()
{
int i=1;
char str[2];
lens=100;
pointer=(student *)malloc(lens*LEN); /*分配内存*/
numstus=0;
welcome(); /*欢迎界面*/
while(i0)
{
i=menu_select(); /*控制菜单*/
switch(i)
{
case 1:addrecord(pointer);break; /*增加学生信息*/
case 2:findrecord(pointer);break; /*查询学生信息*/
case 3:amendrecord(pointer);break; /*修改学生信息*/
case 4:sort(pointer);break; /*学生信息排序*/
case 5:statistic(pointer);break; /*统计信息*/
case 6:openfile(pointer);break; /*打开文件*/
case 7:writetotext(pointer);break; /*保存文件*/
case 8:display(pointer,0,numstus-1);break; /*显示记录*/
case 0:
if(numstus!=0) printf("是否保存当前记录?(y/n)");
gets(str);
if(str[0]=='y'||str[0]=='Y')
writetotext(pointer);
i=-1;break; /*退出系统*/
default:printf("请输入数字0~8:\n");i=1; /*输入错误*/
}
}
printf("\t\t欢迎再次使用本系统。\n\n");
display1();
}
自己一改就能用,给我加分哈!
用SQL语言如何创建学生成绩数据库的代码?
create database [数据库名];\x0d\x0auser [该数据库名];\x0d\x0a\x0d\x0a--学生表\x0d\x0acreate table [学生表表名](\x0d\x0asId int primary key, --学生ID编号,主键\x0d\x0asName varchar(10) unique not null, --学生名字\x0d\x0a);\x0d\x0a\x0d\x0a--科目表\x0d\x0acreate table [科目表表名](\x0d\x0asjId int primary key, --科目ID编号,主键\x0d\x0asjName varchar(10) unique not null, --科目名称\x0d\x0a);\x0d\x0a\x0d\x0a--成绩表\x0d\x0acreate table [成绩表表名]\x0d\x0arId int primary key, --成绩ID编号,主键\x0d\x0asjId int references [科目表表名](sjId), --科目ID编号,继承科目表的ID编号\x0d\x0asId int references [学生表表名](sId), --学生ID编号,继承学生表的ID编号\x0d\x0aresult float not null --成绩\x0d\x0a);\x0d\x0a\x0d\x0a--查询语句\x0d\x0aselect r.rId,sj.sjId,sj.sjName,su.sId,su.sName,r.result \x0d\x0afrom [成绩表表名] r,\x0d\x0ajoin [科目表表名] sj on sj.sjId=r.sjId,\x0d\x0ajoin [学生表表名] su on su.sId=r.sId;
C语言学生成绩管理系统代码
#includestdio.h
#includestring.h
//外部函数声明
void menu();
void line();
/* 定义全局变量其中n代表学生人数,ave[5]代表每科成绩的平均分,high[5]每科成绩的最高分,
min[5]代表每科成绩的最低分,student_ave[100]代表每个学生五门成绩的平均分*/
int n,i,j;
float ave[5]={0},high[5]={0},min[5]={0},student_ave[100];
//定义全局结构体
struct student
{
long int num; //学生学号
char name[20]; //学生姓名
float score[5]; //学生成绩
}stu[100];
//主函数开始
int main()
{
void enter(); //enter:输入学生成绩函数(这是函数声明)
void export(); //export:输出学生成绩函数(这是函数声明)
void stat(); //stat:学生成绩统计函数(这是函数声明)
void rank(); //rank:学生成绩排名函数(这是函数声明)
void query(); //query:学生成绩查询函数(这是函数声明)
//定义内部变量
//界面框架
menu();
printf(" 学生成绩管理信息系统\n");
printf("请根据以下提示命令字符进行操作!\n");
printf("q:退出 a:成绩输入 p:成绩输出 s:成绩统计 w:成绩排名 t:成绩查询\n");
menu();
//函数调用,选择成绩管理方式
printf("请选择成绩管理方式");
while(1)
{
char c;
printf("\n");
scanf("%c",c);
if (c=='q') printf("这是退出学生成绩管理信息系统函数\n\n");break;
switch(c)
{
case'a':enter();break;
case'p':export(); break;
case's':stat();break;
case'v':rank();break;
case't':query();break;
default:("命令无效,请重新输入!\n");
}
}
return 0;
}
//主函数部分结束
//定义函数
void menu()
{
printf("*******************************************************************************\n");
}
//定义下划线函数
void line()
{
printf("--------------------------------------------------------------------------------\n");
}
//定义学生成绩输入函数开始
void enter()
{
menu();
printf("学生成绩输入\n请按以下格式进行数据输入\n");
printf("请输入学生学号姓名");
printf(" 学号 学生姓名\n");
printf("请输入学生成绩 ");
printf(" A成绩 B成绩 C成绩 D成绩 E成绩\n");
printf("例如\n请输入学生学号姓名");
printf("2012060402,张三\n");
printf("请输入学生成绩 ");
printf("95.5,97.0,89.0,92.0,85.0\n");
menu();
//输入学生成绩格式备注
printf("\n请输入学生人数 ");
scanf("%d",n);
//用for循环输入学生成绩
for(i=0;in;i++)
{
printf("请输入学生学号姓名");
scanf("%ld,%s",stu[i].num,stu[i].name);
printf("请输入学生成绩 ");
scanf("%f",stu[i].score[0]);
scanf("%f",stu[i].score[1]);
scanf("%f",stu[i].score[2]);
scanf("%f",stu[i].score[3]);
scanf("%f\n",stu[i].score[4]);
getchar();
student_ave[i]=(stu[i].score[0]+stu[i].score[1]+stu[i].score[2]+stu[i].score[3]+stu[i].score[4])/5;
//用for循环计算每科成绩z总分
for(j=0;j5;j++)
{
ave[j]=ave[j]+stu[i].score[j];
}
//用for循环得出每科成绩最高分
for(j=0;j5;j++)
{
if(high[j]=stu[i].score[j])
{
high[j]=stu[i].score[j];
}
}
//用for循环得出每科成绩最低分
for(j=0;j5;j++)
{
if(i==0)
{
min[j]=stu[i].score[j];
}
if(min[j]=stu[i].score[j])
{
min[j]=stu[i].score[j];
}
}
}
//学生成绩输入完成
//用for循环计算每科成绩平均分
for(j=0;j5;j++)
{
ave[j]=ave[j]/n;
}
getchar();
menu();
printf("\n");
}
//定义学生成绩输入函数结束
//定义学生成绩输出函数开始
void export()
{
int i;
printf(" 学号 姓名 成绩A 成绩B 成绩C 成绩D 成绩E\n");
for(i=0;in;i++)
{
printf("%9ld %15s %7.1f %7.1f %7.1f %7.1f %7.1f\n",stu[i].num,stu[i].name,
stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4]);
}
menu();
}
//定义学生成绩输出函数结束
//定义学生成绩统计函数开始
void stat()
{
printf("各科平均成绩如下!\n");
line();
printf("\n");
printf(" 成绩A 成绩B 成绩C 成绩D 成绩E\n");
//这是每科成绩平均分
for(i=0;i5;i++)
{
printf(" %6.1f ",ave[i]);
}
printf("\n");
printf("\n");
//只是每科成绩的最高分
printf("各科最高分如下!\n");
line();
printf("\n");
printf(" 成绩A 成绩B 成绩C 成绩D 成绩E\n");
for(j=0;j5;j++)
{
printf(" %6.1f ",high[j]);
}
printf("\n");
printf("\n");
//这是每科成绩最低分
printf("各科最低分如下!\n");
line();
printf("\n");
printf(" 成绩A 成绩B 成绩C 成绩D 成绩E\n");
for(i=0;i5;i++)
{
printf(" %6.1f ",min[i]);
}
printf("\n");
printf("\n");
}
//定义学生成绩统计函数结束
//定义学生成绩排名函数开始
void rank()
{
int k=1,z;
float t=0;
float student_high[100]={0};
printf("学生成绩排名如下:\n\n");
line();
printf("\n");
printf("名次 学号 姓名 成绩A 成绩B 成绩C 成绩D 成绩E 平均分 \n");
//把每个学生五门课的成绩按从大到小的顺序排列并存在数组student_high[]中去
for(i=0;in;i++)
{
student_high[i]=student_ave[i];
}
for(j=0;jn;j++)
{
for(i=0;in-j;i++)
{
if(student_high[i]=student_high[i+1])
{
t=student_high[i+1];
student_high[i+1]=student_high[i];
student_high[i]=t;
}
}
}
//按成绩排名输出学生成绩信息
for(i=0;in;i++)
{
for(j=0;jn;j++)
{
if(student_high[i]==student_high[i+1])
{
i++;
}
if(student_high[i]==student_ave[j])
{
printf("%d %ld %15s %7.1f %7.1f %7.1f %7.1f %7.1f %7.1f\n",k,stu[j].num,stu[j].name,
stu[j].score[0],stu[j].score[1],stu[j].score[2],stu[j].score[3],stu[j].score[4],student_ave[j]);
for(z=j+1;zn;z++)
{
if(student_high[i]==student_ave[z])
{
k++;
}
}
}
}
k++;
}
line();
printf("\n");
}
//定义学生成绩排名函数结束
//定义学生成绩查询函数开始
void query()
{
//查询成绩格式
char c2,shu_name[20]; //c2代表查询成绩控制字符。shu_name[]代表输入查询姓名,shu_num代表输入查询学号
int shu_num;
menu();
printf("学生成绩查询\n请按以下方式查询\na:按学生姓名查询 b:按学生学号查询 q:退出\n");
menu();
printf("\n\n");
//选择查询方式
while(c2!='q')
{
printf("请选择查询成绩方式");
scanf("%c",c2);
getchar();
//按姓名查询成绩
if(c2=='a')
{
line();
printf("请输入学生姓名");
scanf("%s",shu_name);
getchar();
for(i=0;in;i++)
{
if(strcmp(shu_name,stu[i].name)==0)
{
printf(" 学号 姓名 成绩A 成绩B 成绩C 成绩D 成绩E\n");
printf("%ld %15s %7.1f %7.1f %7.1f %7.1f %7.1f\n",stu[i].num,stu[i].name,
stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4]);
}
else if(shu_name!=stu[i].namei==(n-1))
{
printf("无此学生成绩\n");
}
}
line();
printf("\n");
}
//按学号查询成绩
else if(c2=='b')
{
line();
printf("请输入学生学号");
scanf("%d",shu_num);
getchar();
for(i=0;in;i++)
{
if(shu_num==stu[i].num)
{
printf(" 学号 姓名 成绩A 成绩B 成绩C 成绩D 成绩E\n");
printf("%ld %15s %7.1f %7.1f %7.1f %7.1f %7.1f\n",stu[i].num,stu[i].name,
stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4]);
}
else if(shu_num!=stu[i].numi==(n-1))
{
printf("无此学生成绩\n");
}
}
line();
printf("\n");
}
}
line();
printf("\n\n");
}
//定义学生成绩查询函数结束
用SQL语言创建学生成绩数据库的代码
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[CangKu]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[CangKu]
GO
CREATE TABLE [dbo].[成绩] (
[学号] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[科目] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL ,
...........
) ON [PRIMARY]
GO
学生成绩管理系统代码
#includeiostream
#includestring
#includefstream
#includecstdlib
#includeiomanip
using namespace std;
class student
{ private:
char name[20]; //姓名
double cpro,english,math,sport,law,hbpro,computer;//课程
int order, number; //名次,学号
public:
student(){}
student(char n[20],int nu,double cc,double eng,double ma,double sp,double l,double hb,double com)
{strcpy(name,n);
number=nu;
cpro=cc; english=eng;math=ma;sport=sp;law=l;hbpro=hb;computer=com;
}
friend void main();
};
void main()
{
cout" 欢迎进入**学生成绩管理系统**!"endl;
cout" ******************************************"endl;
cout" **** 学生成绩管理系统 ****"endl;
cout" ******************************************"endl;
cout" **************************"endl;
cout" **0、输入数据 **"endl;
cout" **1、增加数据 **"endl;
cout" **2、修改数据 **"endl;
cout" **3、按姓名查询 **"endl;
cout" **4、按学号查询 **"endl;
cout" **5、输出所有学生的成绩 **"endl;
cout" **6、退出系统 **"endl;
cout" **************************"endl;
cout" 选择0-6数字进行操作"endl;
char p;char w;
student *s[50]; //指针对象,最多存50个学生数据
ofstream *file[50]; //负责对文件插入操作
int i=0;
int j=0;
int flag=0;
do //flag判断输入是否有效
{
cinp;
if((p='0'p='6'))
flag=1;
else
cout" 指令错误!请重新输入:"endl;
}while(flag==0);
do{
switch(p) //接收功能选项
{
case '0': //输入数据
{
char c;
char name[20];int number;double cpro,english,math,sport,law,hbpro,computer;
do{
cout" 请输入姓名:";
cinname;
coutendl" 请输入学号:";
cinnumber;
cout" 请输入C++成绩:";
cincpro;
coutendl" 请输入英语成绩:";
cinenglish;
coutendl" 请输入数学成绩:";
cinmath;
coutendl" 请输入体育成绩:";
cinsport;
coutendl" 请输入网络基础成绩:";
cinlaw;
coutendl" 请输入C语言成绩:";
cinhbpro;
coutendl" 请输入数据库成绩:";
cincomputer;
coutendl;
file[j]=new ofstream("D:\document",ios::ate);
*file[j]" 姓名 "name" 学号 "number" C++成绩 "cpro
" 英语成绩 "english" 数学成绩 "math" 体育成绩 "
sport" 网络基础成绩 "law" C成绩 "hbpro" 数据库成绩 "computerendl;
j++;
s[i]=new student(name, number,cpro,english,math,sport,law,hbpro,computer);
i++;
cout" 数据输入成功,想继续输入吗(y/n):";
cinc;
coutendl;
do
{
if(c!='y'c!='n')
{
cout" 指令错误!请重新输入!"endl" ";
cinc;
}
else
flag=1;
}while(flag==0);
}while(c=='y');
break;
}
case '1': //增加数据
{
char name[20];
int number;double cpro,english,math,sport,law,hbpro,computer;
char c;
do
{
cout" 请输入您要增加的学生的姓名:";
cinname;
coutendl" 请输入学号:";
cinnumber;
coutendl" 请输入C++成绩:";
cincpro;
coutendl" 请输入英语成绩:";
cinenglish;
coutendl" 请输入数学成绩:";
cinmath;
coutendl" 请输入体育成绩:";
cinsport;
coutendl" 请输入网络基础成绩:";
cinlaw;
coutendl" 请输入C语言成绩:";
cinhbpro;
coutendl" 请输入数据库成绩:";
cincomputer;
coutendl;
file[j]=new ofstream("d:\document",ios::ate);
*file[j]" 姓名 "name" 学号 "number" C++成绩 "cpro" 英语成绩 "english" 数学成绩 "math" 体育成绩 "sport" 网络基础成绩 "law" C成绩 "hbpro" 数据库成绩 "computerendl;
j++;
s[i]=new student(name, number, cpro,english,math,sport,law,hbpro,computer);
i++;
cout" 数据输入成功,想继续数入吗(y/n):";
cinc;
coutendl;
if(c!='y'c!='n')
{
cout" 指令错误!请重新输入!"endl" ";
cinc;
}
}while(c=='y');
break;
}
case '2': //修改数据
{
char name[20];int nu;double cc,eng,ma,sp,l,hb,com;flag=0;
char c;
if(i==0)
{
cout" 管理系统中没有输入数据!"endl;break;
}
do
{
cout" 请输入您要修改的学生的姓名:";
cinname;
coutendl;
for(int h=0;hi;h++) //h纪录要修改学生的位置
{
if(strcmp(name,s[h]-name)==0)
{
flag=1;
cout" 请输入新的学号:";
cinnu;
coutendl" 请输入C++成绩:";
cincc;
coutendl" 请输入英语成绩:";
cineng;
coutendl" 请输入数学成绩:";
cinma;
coutendl" 请输入体育成绩:";
cinsp;
coutendl" 请输入网络基础成绩:";
cinl;
coutendl" 请输入C语言成绩:";
cinhb;
coutendl" 请输入数据库成绩:";
cincom;
coutendl;
s[h]-cpro=cc;
s[h]-english=eng;
s[h]-math=ma;
s[h]-sport=sp;
s[h]-law=l;
s[h]-hbpro=hb;
s[h]-computer=com;
s[h]-number=nu;
cout" 数据修改成功!"endl;
}
}
if(flag==0)
{
cout" 您要修改的学生本来就不存在!请检查重新输入!"endl;
}
cout" 想继续修改吗(y/n):";
cinc;
coutendl;
if(c!='y'c!='n')
{
cout" 指令错误!请重新输入!"endl" ";
cinc;
}
}while(c=='y');
break;
}
case '3': //按姓名查询
{
char n[20];int j=0;char c;
if(i==0)
{
cout" 管理系统中没有输入数据!"endl;break;
}
do{
int flag=0;
cout" 请输入你要查询的学生姓名:";
cinn;
coutendl;
for(int j=0;ji;j++)
{
if(strcmp(n,(*s[j]).name)==0)
{
flag=1;
cout" 您要查询的学生是:"(*s[j]).nameendl;
cout(*s[j]).name"的成绩是: "" C++: "(*s[j]).cpro" 英语: "(*s[j]).english" 数学:"(*s[j]).math" 体育:"(*s[j]).sport" 法律:"(*s[j]).law" C:"(*s[j]).hbpro" 数据库 "(*s[j]).computerendl;
}
}
if(flag==0)
cout" 对不起!您要查询的学生不存在!"endl;
cout" 您想继续查询吗?(y/n):";
cinc;
coutendl;
if(c!='y'c!='n')
{
cout" 指令错误!请重新输入!"endl;
cinc;
}
}
while(c=='y');
break;
}
case '4': //按学号查询
{
int n,j=0;char c;
if(i==0){
cout" 管理系统中没有输入数据!"endl;break;
}
do{
int flag=0;
cout" 请输入你要查询的学生的学号:";
cinn;
coutendl;
for(int j=0;ji;j++)
{
if(s[j]-number==n)
{
flag=1;
cout" 您要查询的学生是:"(*s[j]).nameendl;
cout(*s[j]).name"的成绩是: "" C++:"(*s[j]).cpro" 英语:"(*s[j]).english" 数学:"(*s[j]).math" 体育:"(*s[j]).sport" 法律:"(*s[j]).law" C:"(*s[j]).hbpro" 数据库 "(*s[j]).computerendl;
}
}
if(flag==0)
cout" 对不起!您要查询的学生不存在!"endl;
cout" 您想继续查询吗?(y/n):";
cinc;
coutendl;
if(c!='y'c!='n')
{
cout" 指令错误!请重新输入!"endl;
cinc;
}
}
while(c=='y');
break;
}
case '5': //输出
{
cout" 本系统所有学生数据如下:"endl;
if(i==0)
cout" 管理系统中没有输入数据!"endl;
cout" 姓名 学号 c++ 英语 数学 体育 网络基础 C语言 数据库 "endl;
for(int k=0;ki;k++)
{
couts[k]-namesetw(7)s[k]-numbersetw(6)
(*s[k]).cprosetw(6)(*s[k]).englishsetw(6)
(*s[k]).mathsetw(6)(*s[k]).sportsetw(7)
(*s[k]).law setw(10)(*s[k]).hbprosetw(10)(*s[k]).computersetw(10)endl;
}
break;
}
case'6'://退出
{exit(0); cout"Bye bye!"endl;}
}
cout" 您想继续进行其他操作吗?(y/n):";
int flag=0;
do
{
cinw;
coutendl;
if(w!='y'w!='n')
cout" 指令错误!请重新输入!"endl;
else
flag=1;
}while(flag==0);
if(w=='y')
cout" 请输入操作代码:0 输入数据"endl;
cout" 1 增加数据"endl;
cout" 2 修改数据"endl;
cout" 3 按姓名查询"endl;
cout" 4 按学号查找"endl;
cout" 5 输出所有学生成绩"endl;
cout" 6 退出系统"endl;
cinp;
}while(w=='y');
}
学生成绩系统数据库代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于学生成绩查询代码、学生成绩系统数据库代码的信息别忘了在本站进行查找喔。
版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;
相关推荐
- 05-14上海网站推广系统,上海网站推广服务公司
- 05-13电脑系统优化软件哪个好用,电脑系统优化在哪里
- 05-12网站自然优化,网站自动优化系统
- 05-12cms系统,喜来健CMS系统
- 05-11自助建站系统源码,自助建站源码php
- 05-09网页代码,网页代码快捷键
- 05-08青岛关键词排名系统,青岛关键词排名首页
- 05-07网易推广员系统登录,网易推广员系统推广平台
- 05-06单页网站的代码(完整的网页代码)[20240506更新]
- 05-06个人主页图片代码(个人主页图片代码怎么弄)[20240506更新]
取消回复欢迎 你 发表评论:
- 标签列表
- 最近发表
- 友情链接