当前位置:首页 > 代码 > 正文

学生成绩系统数据库代码(学生成绩查询代码)

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站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/2686.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载