当前位置:首页 » 考试成绩 » 学生查询课程成绩的时序图

学生查询课程成绩的时序图

发布时间: 2021-02-08 23:37:54

1. SQL查询,学生表,课程表,成绩表的一个查询要求如下怎么写呢

selects.sid,s.sname,sc.scorefromstudent,course,scwherestudent.sid=sc.sidandcourse.cid=sc.cidandcourse.cname='影视设计';

注意一下,你自己写的sid和sname中间没有逗号,到时候一定执行报错

2. 怎么用SQL语句查询每个学生选修的课程名及其成绩

select 姓名,课程名,成绩 from (课程名所在的表名 C join 成绩所在的表名 S on C.课程号=S.课程号) join 学生信息表 on S.学号=学生信息表.学号 ;

具体的例子:
select Sname,Cname,Grade from Student st left join(Score s left join Course c on s.Cno=c.Cno)
on st.Sno=s.Sno;

3. 学生表(学号,姓名)、课程表(课程编号,课程名)、成绩表(自动编号、学号,课程编号,成绩) 查询各个学生学

select A.姓名,
sum(case B.课程名 when '语文' then C.成绩 else 0 end) as 语文,
sum(case B.课程名 when '数学' then C.成绩 else 0 end) as 数学,
sum(case B.课程名 when '英语' then C.成绩 else 0 end) as 英语,
sum(case B.课程名 when '历史' then C.成绩 else 0 end) as 历史,
from 学生表 A left join 成绩表 C on 学生表.学号=成绩表.学号
left join 课程表 B on 成绩表.课程编号=课程表.课程编号
group by A.姓名
刚刚不是在那边回答你了么~~~

4. 设计一个学生成绩管理系统,能对学生成绩信息(学号,课程名称,成绩)进行查询(要求可以使用模糊查询和

简单模式,具体功能你自己可以继续编写

#include<stdio.h>
#include<string.h>
#include<conio.h>

struct student{
char number[20];
char name[30];
float scor_eng;
float scor_math;
float scor_phy;
};
void printmenu();
int mycreat(int xueshengnumber,struct student record[100]);
void myshow(int xueshengnumber,struct student record[100]);
void myselect(int xueshengnumber,struct student record[100]);
void mymodify(int xueshengnumber,struct student record[100]);
int myadd(int xueshengnumber,struct student record[100]);
int mydelete(int xueshengnumber,struct student record[100]);
void mysort(int xueshengnumber,struct student record[100]);

/* ------------------------------------------------------------------*/
main()
{
char choose,yesorno;
struct student record[100]; //用结构体代替原来的5个数组

int xueshengnumber=0; /*输入的学生数 */
do
{
printmenu(); /* 打印菜单界面 */
choose=getch();
while(choose>'7'||choose<'0')
{
printf("请在0-7之间选择\n");
choose=getch();
}
switch(choose)
{
case '1':
{
xueshengnumber=mycreat(xueshengnumber,record);
break;
}
case '2':
{
myshow(xueshengnumber,record);
break;
}
case '3':
{
myselect(xueshengnumber,record);
break;
}
case '4':
{
mymodify(xueshengnumber,record);
break;
}
case '5':
{
xueshengnumber=myadd(xueshengnumber,record);
break;
}
case '6':
{
xueshengnumber=mydelete(xueshengnumber,record);
break;
}
case '7':
{
mysort(xueshengnumber,record);
break;
}
case '0':
{
printf("确实要退出系统吗?");
break;
}
}

printf("\n要继续选择吗{Y/N}\n");
do
yesorno=getch();
while(yesorno!='Y'&&yesorno!='N'&&yesorno!='y'&&yesorno!='n');
}while(yesorno=='Y'||yesorno=='y');

}
/* ------------------------------------------------------------------*/

void printmenu()
{
printf("|----------------------------------------------------------------------|\n");
printf("| 学生成绩管理系统,请选择数字进行相应操作 |\n");
printf("| 1:录入学生成绩(包括姓名、学号、英语、数学、物理),输入完成按“结束”|\n");
printf("| 2:显示学生成绩; |\n");
printf("| 3:查询学生成绩; |\n");
printf("| 4:修改学生成绩; |\n");
printf("| 5:添加学生成绩; |\n");
printf("| 6:删除学生成绩; |\n");
printf("| 7:排序学生成绩; |\n");
printf("| 0:退出该成绩; |\n");
printf("|----------------------------------------------------------------------|\n");
}

int mycreat(int xueshengnumber,struct student record[100])
{/*----------------------------------------*/
struct student temp;

int x;
printf("请输入第%d个记录:\n",xueshengnumber+1);
printf("姓名(用#结束):\n");
do
gets(temp.name);
while(strcmp(temp.name,"")==0);
printf("学号(用#结束):\n");
do
gets(temp.number);
while(strcmp(temp.number,"")==0);
printf("英语成绩:\n");
do
{
fflush(stdin);
x=scanf("%f",&temp.scor_eng); /*返回值含义见P38*/
}while(temp.scor_eng>100.0||temp.scor_eng<0.0||x==0);
printf("数学成绩:\n");
do
{

fflush(stdin);
x=scanf("%f",&temp.scor_math);
}while(temp.scor_math>100.0||temp.scor_math<0.0||x==0);
printf("物理成绩:\n");
do
{

fflush(stdin);
x=scanf("%f",&temp.scor_phy);
}while(temp.scor_phy>100.0||temp.scor_phy<0.0||x==0);

/* 输入结束控制 */
while(temp.name[0]!='#' && temp.number[0]!='#')
{
/*保存到数组中 */
record[xueshengnumber]=temp;

xueshengnumber++;

/* 重复上次输入 */
printf("请输入第%d个记录:\n",xueshengnumber+1);
printf("姓名(用#结束):\n");
do
gets(temp.name);
while(strcmp(temp.name,"")==0);
printf("学号(用#结束):\n");
do
gets(temp.number);
while(strcmp(temp.number,"")==0);
printf("英语成绩:\n");
do
{
fflush(stdin);
x=scanf("%f",&temp.scor_eng); /*返回值含义见P38*/
}while(temp.scor_eng>100.0||temp.scor_eng<0.0||x==0);
printf("数学成绩:\n");
do
{

fflush(stdin);
x=scanf("%f",&temp.scor_math);
}while(temp.scor_math>100.0||temp.scor_math<0.0||x==0);
printf("物理成绩:\n");
do
{

fflush(stdin);
x=scanf("%f",&temp.scor_phy);
}while(temp.scor_phy>100.0||temp.scor_phy<0.0||x==0);
}
/*----------------------------------------*/
return(xueshengnumber);
}

/* 显示模块 */
void myshow(int xueshengnumber,struct student record[100])
{
int i;
if(xueshengnumber==0) printf("请先录入学生成绩,再显示学生成绩\n");
else
{
printf("\n\n\n显示所有学生成绩\n");
printf("姓名 学号 英语成绩 数学成绩 物理成绩\n");
for(i=0;i<xueshengnumber;i++)
{
printf("%-15s",record[i].name);
printf("%-15s",record[i].number);
printf("%-13f",record[i].scor_eng);
printf("%-13f",record[i].scor_math);
printf("%-13f",record[i].scor_phy);
printf("\n");
}
}
}

/* 查询模块 */
void myselect(int xueshengnumber,struct student record[100])
{
int i;
char tempnumber[20]="";

printf("\n\n请输入要查询的学生学号:");

do
gets(tempnumber);
while(strcmp(tempnumber,"")==0);

for(i=0;i<xueshengnumber;i++)
if(strcmp(tempnumber,record[i].number)==0)
{

printf("查询结果:\n");
printf("姓名 学号 英语成绩 数学成绩 物理成绩\n");
printf("%-15s",record[i].name);
printf("%-15s",record[i].number);
printf("%-13f",record[i].scor_eng);
printf("%-13f",record[i].scor_math);
printf("%-13f",record[i].scor_phy);
printf("\n");
}

}

void mymodify(int xueshengnumber,struct student record[100])
{
int i;
struct student temp;

printf("请输入要修改的学生学号\n");
do
gets(temp.number);
while(strcmp(temp.number,"")==0);

for(i=0;i<xueshengnumber;i++)
if(strcmp(temp.number,record[i].number)==0) break; //从此分支出来的i是有此学生的
if(i==xueshengnumber) //表明整个循环走完了也没找到与tempnumber相等的学号
printf("查询结果无此学生\n");
else
{
printf("请输入要修改的学生姓名\n");
do
gets(temp.name);
while(strcmp(temp.name,"")==0);
strcpy(record[i].name,temp.name);
printf("请输入要修改的英语成绩\n");
do
{ fflush(stdin);
scanf("%f",&temp.scor_eng);
}
while(temp.scor_eng>100.0||temp.scor_eng<0.0);
record[i].scor_eng=temp.scor_eng;
printf("请输入要修改的数学成绩\n");
do
{ fflush(stdin);
scanf("%f",&temp.scor_math);
}
while(temp.scor_math>100.0||temp.scor_math<0.0);
record[i].scor_math=temp.scor_math;
printf("请输入要修改的物理成绩\n");
do
{ fflush(stdin);
scanf("%f",&temp.scor_phy);
}
while(temp.scor_phy>100.0||temp.scor_phy<0.0);
record[i].scor_phy=temp.scor_phy;
}
}

int myadd(int xueshengnumber,struct student record[100])
{
int i;
struct student temp;

printf("请输入要添加的学生学号\n");
do
gets(temp.number);
while(strcmp(temp.number,"")==0);
for(i=0;i<xueshengnumber;i++)
if(strcmp(temp.number,record[i].number)==0)
{printf("该学号已经存在,请重新输入要添加的学生学号\n");
do
gets(temp.number);
while(strcmp(temp.number,"")==0);
i=-1;
}
strcpy(record[i].number,temp.number);
printf("请输入要添加的学生姓名\n");
do
gets(temp.name);
while(strcmp(temp.name,"")==0);
strcpy(record[i].name,temp.name);
printf("请输入要添加的英语成绩\n");
do
{ fflush(stdin);
scanf("%f",&temp.scor_eng);
}
while(temp.scor_eng>100.0||temp.scor_eng<0.0);
record[i].scor_eng=temp.scor_eng;
printf("请输入要添加的数学成绩\n");
do
{ fflush(stdin);
scanf("%f",&temp.scor_math);
}
while(temp.scor_math>100.0||temp.scor_math<0.0);
record[i].scor_math=temp.scor_math;
printf("请输入要添加的物理成绩\n");
do
{ fflush(stdin);
scanf("%f",&temp.scor_phy);
}
while(temp.scor_phy>100.0||temp.scor_phy<0.0);
record[i].scor_phy=temp.scor_phy;
xueshengnumber++;
return xueshengnumber;
}

int mydelete(int xueshengnumber,struct student record[100])
{
int i;
struct student temp;

printf("请输入要删除的学生学号:");
do
gets(temp.number);
while(strcmp(temp.number,"")==0);
for(i=0;i<xueshengnumber;i++)
if(strcmp(temp.number,record[i].number)==0) break;
if(i<xueshengnumber)
{
if(i+1==xueshengnumber) xueshengnumber--;
else{
for(;i<xueshengnumber-1;i++)
{
record[i]=record[i+1];
}
xueshengnumber--;

}
}
else
printf("查无此学生");
return xueshengnumber;
}

void mysort(int xueshengnumber,struct student record[100])
{ int i,j;

struct student t;
printf("按学号从小到大地排序\n");
for(i=0;i<xueshengnumber-1;i++)
for(j=0;j<xueshengnumber-1-i;j++)
if(strcmp(record[j].number,record[j+1].number)>0)
{
t=record[j];
record[j]=record[j+1];
record[j+1]=t;

}
}

5. 设计一个学生成绩管理系统,学生成绩信息包括:学号,姓名,四门课成绩,实现功能如下:

//我简单写,请借鉴:
#include"stdafx.h"
#include"stdio.h"
#include"string.h"
#include"math.h"
#include"time.h"
#include"string.h"#include<iostream>
usingnamespacestd;

structStudent//定义学生结构
{
charid[20];//id
charname[11];//姓名
charres[4];//成绩
intend;//存储时显示换行,可去掉
Student(){end=0x0a0d;}//回车,换行

}list[100];//100个账号,测试

voidmain()
{
srand((unsigned)time(0));//种子
charbuf[256];//缓存

//初始化学生100名
inti;
for(i=0;i<100;++i)
{
strcpy(list[i].id,itoa(i,buf,10));
strcpy(list[i].name,"某人");
strcpy(list[i].res,itoa(rand()%100,buf,10));
}

//保存数据
FILE*pf=fopen("data.txt","wb");

for(i=0;i<100;++i)
{
fwrite(&list[i],sizeof(Student),1,pf);
}
fclose(pf);

//读出数据
Studentlist_1[100];//新数组
pf=fopen("data.txt","rb");
for(i=0;i<100;++i)
{
fread(&list_1[i],sizeof(Student),1,pf);
}

//显示list_1测试
for(i=0;i<100;++i)
{
cout<<list_1[i].id<<""<<list_1[i].name<<""<<list_1[i].res<<endl;
}}

6. SQL数据库,三个表,查询学生某一门课程的成绩

SELECTa.S#AS学号,a.SnameAS姓名,c.scoreAS物理版成绩权
FROMStudenta,Courseb,SCc
WHEREa.S#=c.S#ANDb.C#=c.C#ANDb.Cname='物理'

7. sql,查询每门课程最高分的学生的学号,课程号,成绩。再一张表里

1、首先在打开的sql中,查看Market数据库中供应商来自哪些州的哪些城市,如内下图所示。

8. 数据库查询选修某课程学生的成绩,并按降序排序

这是一个参数查询题,实现sql代码如下:
select
学号,成绩
from
学生成绩
where
课程编号=[请输入课程编号]
order
by
成绩
desc;
表名和字段名请按实际调整

9. 数据库多表查询,学生表,课程表,成绩表

直接将三表关联查询就可以了
select b.姓名,c.课程,a.成绩
from 成绩表 a,学生表 b,课程表 c
where a.学生学号 = b.学号 and a.课程编号 = c.编号 and a.成绩 < 60

10. 一张学生成绩表内SQL查询每个班级每门课程的平均分

select avg(分数复制) as 平均分, rtrim(cast(sum(case when 分数>=60 then 1 end)/count(*)*100 as char(10)))+'%' as 及格率 from A group by 班级,课程

热点内容
武汉大学学生会辅导员寄语 发布:2021-03-16 21:44:16 浏览:612
七年级学生作文辅导学案 发布:2021-03-16 21:42:09 浏览:1
不屑弟高考成绩 发布:2021-03-16 21:40:59 浏览:754
大学毕业证会有成绩单 发布:2021-03-16 21:40:07 浏览:756
2017信阳学院辅导员招聘名单 发布:2021-03-16 21:40:02 浏览:800
查询重庆2018中考成绩查询 发布:2021-03-16 21:39:58 浏览:21
结业考试成绩怎么查询 发布:2021-03-16 21:28:40 浏览:679
14中医医师资格笔试考试成绩查分 发布:2021-03-16 21:28:39 浏览:655
名著赏析课程标准 发布:2021-03-16 21:27:57 浏览:881
北京大学商业领袖高端培训课程 发布:2021-03-16 21:27:41 浏览:919