数据库教务系统管理表

 2025-01-10 01:54:01  阅读 492  评论 0

摘要:晕,一看就知道你是初学者,这是最简单的主外键关联:1、一个教员可讲授多门课程,一门课程只能被一个教员讲授:课程表中加一个教员ID的外键用来指向教员表中主键ID2、一个学生选修多门课程,每门课程有多个学生选修,学生学习有成绩:这是多对多的关系,创建一个关联表用来关

晕,一看就知道你是初学者,这是最简单的主外键关联:

1、一个教员可讲授多门课程,一门课程只能被一个教员讲授:课程表中加一个教员ID的外键用来指向教员表中主键ID

数据库教务系统管理表

2、一个学生选修多门课程,每门课程有多个学生选修,学生学习有成绩:这是多对多的关系,创建一个关联表用来关联学生表和课程表,有两个外键一个是学生ID,一个是课程ID,然后一个成绩的字段即可。

3、一门课只在一个教室上,一个教室可上多门课:课程表中添加一个教室ID的外键指向教室表的主键ID。

因此需要以下表:

教员表:主键ID、职工号、姓名、年龄、职称

学生表:主键ID、学号、姓名、年龄、性别

课程表:主键ID、课程号、课程名、课时数、教员ID(外键ID)、教室ID

学生、教程关联表:主键ID、学生ID、课程ID、成绩

教室表:主键ID、教室编号、地址、容量

某学校教学管理数据库jxgl.dbc中有三个表:学生表,课程表和成绩表,内容如下: 学生表:

各表都只列出了主要属性,其余属性自己根据需求加吧

模型指标什么的太深奥了,看上去像是多对多的关系。

所以第一部分至少3张表

指标表:指标ID (主键)

模型表:模型ID (主键)

模型指标对应表:指标ID,模型ID(复合主键)

学生和课程也是多对多的关系,

所以也有跟上面类似的三张表,用户表(加个权限字段区分学生老师管理员教务人员,主键:用户ID),课程表:课程ID (主键),选课表:用户ID,课程ID (复合主键)

你的教师和课程应该是一对一的关系吧,把教师的用户ID作为外键添加到课程表里。

至于样本管理,描述不是很清楚,看样子应该跟模型一一对应的吧,样本表:样本ID(主),模型ID(外)

第三部分

评价表1 评价表ID(主),用户ID(外)

评价表2 评价表ID,模型ID(复合主键)

已知一个教学管理数据库JXGL,包含以下三张数据表:学生表、课程表以及学生成绩表。它们的结构如下:

(1)创建学生表、课程表和成绩表。具体要求:学生表中学号为主索引,出生日期默认值为1988-09-01;课程表中课程号为主索引,学分不能为空;成绩表中学号是外索引与学生表建立关系,课程号是外索引与课程表建立关系,成绩的要求是在0-100之间。

createtable 学生表

(学号intnotnullprimarykey,

姓名varchar(30)notnull,

性别varchar

(4)notnull,

出生日期datetimenotnulldefault 1988-09-01

)

go

createtable 课程表

(课程号char

(6)notnullprimarykey,

课程名varchar(30)notnull,

学分char(10)notnull

)

go

createtable 成绩表

(学号intconstraintWZ1foreignkeyreferences 学生表(学号),

课程号char

(6)constraintWZ2foreignkeyreferences 课程表(课程号),

成绩 tinyintconstraint 成绩_ckcheck (成绩>=0 and 成绩<=100 )

)

(2)通过insert into命令向各表中输入记录(按照所给表的内容)

insert into 学生表values (10001,'张娟娟','女','1987-09-01')

insert into 学生表values (10002,'李斌','男','1988-03-01')

insert into 学生表values (10003,'王亮晶','女','1986-05-04')

insert into 学生表values (10004,'成果果','女')

insert into 课程表values ('K01','VFP程序设计','3.5')

insert into 课程表values ('K02','计算机文化基础','2')

insert into 成绩表values (10001,'K01 ','85')

insert into 成绩表values (10001,'K02 ','90')

insert into 成绩表values (10002,'K01 ','88')

insert into 成绩表values (10002,'K02 ','92')

insert into 成绩表values (10003,'K01 ','90')

insert into 成绩表values (10003,'K02 ','91')

insert into 成绩表values (10004,'K01 ','76')

insert into 成绩表values (10004,'K02 ','87')

(3)查询“VFP程序设计”课程的学号和成绩并按降序输出。

select 课程表.课程名,成绩表.学号,成绩表.成绩from 成绩表

join 课程表on 成绩表.课程号=课程表.课程号

where 课程表.课程名='VFP程序设计'

orderby 成绩表.成绩desc

(4)查询“成果果”的学号和成绩。

select 学生表.姓名,成绩表.学号,成绩表.成绩from 成绩表

join 学生表on 成绩表.学号=学生表.学号

where 学生表.姓名='成果果'

(5)查询“张娟娟”的学号和出生日期。

select 学号,姓名,出生日期from 学生表where 姓名='张娟娟'

(6)查询课程号为“K01”的成绩。

select 课程号,成绩from 成绩表where 课程号='K01'

(7)查询“王亮晶”的“计算机文化基础”成绩。

select 学生表.姓名,课程表.课程名,成绩表.成绩from 成绩表

join 课程表on 成绩表.课程号=课程表.课程号

join 学生表on 学生表.学号=成绩表.学号

where 课程表.课程名='计算机文化基础'and 学生表.姓名='王亮晶'

select * from 学生表 where 专业 =(select 专业 from 学生表 where name='苗舟')

order by age desc

1、select 学号, avg(成绩) from 成绩表 group by 学号 having avg(成绩)>70

2、delete from 成绩表 where 学号=33

3、delete from 成绩表 where 学号 in (select 学号 from 学生表 where name='刘涛')

4、delete from 成绩表 where 学号 in (

select 学号 from 学生表 where age<(select min(age) from 学生表 where sex='男')

and sex='女')

delete from 学生表 where age<(select min(age) from 学生表 where sex='男')

and sex='女'

以上就是关于SQL server 2005数据库如何建表:某教学管理系统涉及教员、学生、课程、教室四个实体全部的内容,如果了解更多相关内容,可以关注,你们的支持是我们更新的动力!

版权声明:我们致力于保护作者版权,注重分享,被刊用文章【数据库教务系统管理表】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!;

原文链接:https://www.yxiso.com/zhishi/913162.html

发表评论:

关于我们
院校搜的目标不仅是为用户提供数据和信息,更是成为每一位学子梦想实现的桥梁。我们相信,通过准确的信息与专业的指导,每一位学子都能找到属于自己的教育之路,迈向成功的未来。助力每一个梦想,实现更美好的未来!
联系方式
电话:
地址:广东省中山市
Email:beimuxi@protonmail.com

Copyright © 2022 院校搜 Inc. 保留所有权利。 Powered by BEIMUCMS 3.0.3

页面耗时0.0720秒, 内存占用1.98 MB, 访问数据库27次

陕ICP备14005772号-15