1. 写出用Create Table创建表student1、course1、sc1 ,并按下列要求设置完整性约束。要求: (1)Student1表 属性:Sno(学号) Sname(姓名) Ssex(性别) Sage (年龄) Sdept(系部) student 的约束: 主码:sno Sname不可为空,且唯一 性别 不能为空且取值范围为{男,女} 年龄大于16岁 (2) Course1表 属性:Cno(课程号) Cname(课程名) Cpno(先修课号) Ccredit(学分) course 的约束: 主码:cno Ccredit 取值范围[ 1-6 ] Course表的外码Cpno ,参照表Course的Cno (3) SC1表 属性:Sno(学号) Cno(课程号) Grade(成绩) SC1 的约束: 主码:(sno,cno) ,主码名为 PK_SC 成绩(grade)只能在 0 – 100分之间 Sc1的外码:  外码:SC 表的sno 参照表 student 的 sno  外码:sc 表的Cno 参照表 course 的 cno 2 实体完整性验证

时间: 2024-01-08 08:02:55 浏览: 43
1. 创建表语句如下: ```sql -- 创建 Student1 表 CREATE TABLE student1 ( Sno VARCHAR(10) PRIMARY KEY, Sname VARCHAR(20) NOT NULL UNIQUE, Ssex VARCHAR(2) NOT NULL CHECK (Ssex IN ('男', '女')), Sage INT NOT NULL CHECK (Sage > 16), Sdept VARCHAR(20) ); -- 创建 Course1 表 CREATE TABLE course1 ( Cno VARCHAR(10) PRIMARY KEY, Cname VARCHAR(20) NOT NULL, Cpno VARCHAR(10) REFERENCES course1(Cno), Ccredit INT CHECK (Ccredit BETWEEN 1 AND 6) ); -- 创建 SC1 表 CREATE TABLE sc1 ( Sno VARCHAR(10) REFERENCES student1(Sno), Cno VARCHAR(10) REFERENCES course1(Cno), Grade INT CHECK (Grade BETWEEN 0 AND 100), PRIMARY KEY (Sno, Cno) ); ``` 2. 实体完整性验证是指保证数据表中每条记录的实体完整性,即每条记录都代表一个真实存在的实体。在本题中,需要验证以下实体的完整性: - Student1 表中的每个 Sno 对应一个唯一的学生信息 - Course1 表中的每个 Cno 对应一个唯一的课程信息 - SC1 表中的每个 (Sno, Cno) 对应一个唯一的成绩信息 验证方法如下: - 对于 Student1 表和 Course1 表,可以通过查询每个 Sno/Cno 对应的记录数,保证每个 Sno/Cno 对应一个唯一的实体。 ```sql -- 查询 Student1 表中每个 Sno 对应的记录数 SELECT Sno, COUNT(*) FROM student1 GROUP BY Sno HAVING COUNT(*) > 1; -- 查询 Course1 表中每个 Cno 对应的记录数 SELECT Cno, COUNT(*) FROM course1 GROUP BY Cno HAVING COUNT(*) > 1; ``` 如果查询结果为空,则说明实体完整性验证通过。 - 对于 SC1 表,可以通过查询每个 (Sno, Cno) 对应的记录数,保证每个 (Sno, Cno) 对应一个唯一的实体。 ```sql -- 查询 SC1 表中每个 (Sno, Cno) 对应的记录数 SELECT Sno, Cno, COUNT(*) FROM sc1 GROUP BY Sno, Cno HAVING COUNT(*) > 1; ``` 如果查询结果为空,则说明实体完整性验证通过。

相关推荐

1.  在学生表上创建姓名列的前4个字符的降序索引sno_4_in 2.  在学生表上创建班级列的索引 3.  对课程表进行修改,增加学分列上的升序索引credit_in 4.  创建一个表t1,包含f1,f2,f3列,数据类型分别为int,char,varchar,在创建表时创建f1列的索引。 5.  删除我们4题的索引 6.  用自己的语言描述分区的功能。 7.  创建一张RANGE分区表,包含3个字段,表名及字段名自定义,第一个字段为整数类型,第二个字段为日期类型。以第一个字段为分区依据,分为4个分区。 8.                                                对tb_hash_blog表分区情况进行描述,分区类型是什么,分区依据是什么,分为几个区等等。 9.  创建一个学号,姓名,性别,年龄的视图view_s,按性别统计人数 10. 在学生成绩管理数据库中创建每门课程的平均成绩视图view_c_avg,查询成绩60以下的信息 11. 在学生成绩管理数据库中创建一个每个学生的平均成绩视图view_s_avg,从该视图中查询,平均成绩在85分以上的信息 12. 创建一个学号,姓名,性别,课程号,课程名称,成绩的视图view_sc1,统计每个学生修了多少们课程。 13. 通过视图view_s插入一名学生('2020001','gigi','m',22). 14. 创建课程表的视图view_c,利用该视图给每门课程加一个学分。 15. 利用视图view_c删除学分在5分以上的课程

最新推荐

recommend-type

WX小程序源码小游戏类

WX小程序源码小游戏类提取方式是百度网盘分享地址
recommend-type

grpcio-1.47.2-cp310-cp310-musllinux_1_1_x86_64.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

cryptography-42.0.3-cp37-abi3-musllinux_1_1_x86_64.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

2021131528+谢镕汕.zip

2021131528+谢镕汕.zip
recommend-type

sja1301.i386.tar.gz

SQLyong 各个版本,免费下载 SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。