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 ,参照表Course1的Cno (3) SC1表 属性:Sno(学号) Cno(课程号) Grade(成绩) SC1 的约束: 主码:(sno,cno) ,主码名为 PK_SC 成绩(grade)只能在 0 – 100分之间 Sc1的外码:  外码:SC1 表的sno 参照表 student1 的 sno  外码:SC1 表的Cno 参照表 course1 的 cno

时间: 2023-06-27 14:06:32 浏览: 139
创建表student1: ```sql CREATE TABLE student1 ( Sno VARCHAR(10) PRIMARY KEY, Sname VARCHAR(20) UNIQUE NOT NULL, Ssex VARCHAR(2) NOT NULL CHECK (Ssex IN ('男', '女')), Sage INT NOT NULL CHECK (Sage > 16), Sdept VARCHAR(20) ); ``` 创建表course1: ```sql CREATE TABLE course1 ( Cno VARCHAR(10) PRIMARY KEY, Cname VARCHAR(20), Cpno VARCHAR(10) REFERENCES course1(Cno), Ccredit INT CHECK (Ccredit >= 1 AND Ccredit <= 6) ); ``` 创建表sc1: ```sql CREATE TABLE sc1 ( Sno VARCHAR(10) REFERENCES student1(Sno), Cno VARCHAR(10) REFERENCES course1(Cno), Grade INT CHECK (Grade >= 0 AND Grade <= 100), PRIMARY KEY (Sno, Cno) CONSTRAINT PK_SC ); ```
相关问题

1. 写出用Create Table创建表student1、course1、sc1 ,并按下列要求设置完整性约束。要求: (1)Student1表 属性:Sno(学号) Sname(姓名) Ssex(性别) Sage (年龄) Sdept(系部) student 的约束: 主码:sno Sname不可为空,且唯一 性别 不能为空且取值范围为{男,女} check (ssex in (‘男’,‘女’)) 年龄大于16岁 check

以下是用Create Table创建表student1并设置完整性约束的SQL语句: ```sql CREATE TABLE student1 ( Sno CHAR(10) PRIMARY KEY, Sname VARCHAR(20) UNIQUE NOT NULL, Ssex CHAR(2) NOT NULL CHECK (Ssex IN ('男', '女')), Sage INT CHECK (Sage > 16), Sdept VARCHAR(20) NOT NULL ); ``` 其中,Sno为CHAR类型,长度为10,作为主键;Sname为VARCHAR类型,长度为20,不可为空,且唯一;Ssex为CHAR类型,长度为2,不可为空,且取值范围为{男,女};Sage为INT类型,不可为空,且必须大于16;Sdept为VARCHAR类型,长度为20,不可为空。 同样的方式,可以创建course1和sc1表,并设置相应的约束。

1. 使用Create Table 命令建立带有完整性约束的三个表:student1、course1、sc1,并通过数据更新对完整性规则进行验证。mysql实验总结

本次实验的目的是使用MySQL的Create Table命令建立带有完整性约束的三个表,验证完整性规则是否正确。下面是实验步骤及总结: 1. 创建数据库:首先打开MySQL命令行界面,并输入以下命令来创建一个名为test的数据库: ``` CREATE DATABASE test; ``` 2. 使用test数据库:使用以下命令来使用test数据库: ``` USE test; ``` 3. 创建Student1表:使用以下命令来创建Student1表,并设定主键、非空和唯一约束: ``` CREATE TABLE Student1( SNO CHAR(10) PRIMARY KEY, SNAME CHAR(20) NOT NULL, SAGE INT NOT NULL, SADDRESS CHAR(50), UNIQUE(SNAME) ); ``` 4. 创建Course1表:使用以下命令来创建Course1表,并设定主键和非空约束: ``` CREATE TABLE Course1( CNO CHAR(10) PRIMARY KEY, CNAME CHAR(20) NOT NULL, CREDIT INT NOT NULL ); ``` 5. 创建SC1表:使用以下命令来创建SC1表,并设定主键、外键和非空约束: ``` CREATE TABLE SC1( SNO CHAR(10), CNO CHAR(10), GRADE INT NOT NULL, PRIMARY KEY(SNO,CNO), FOREIGN KEY(SNO) REFERENCES Student1(SNO), FOREIGN KEY(CNO) REFERENCES Course1(CNO) ); ``` 6. 验证完整性规则:接下来,我们可以插入一些数据来验证完整性规则是否正确。首先,插入一条SNO为"001"、SNAME为"张三"、SAGE为18、SADDRESS为"北京"的记录到Student1表中: ``` INSERT INTO Student1 VALUES('001','张三',18,'北京'); ``` 然后,插入一条CNO为"001"、CNAME为"语文"、CREDIT为3的记录到Course1表中: ``` INSERT INTO Course1 VALUES('001','语文',3); ``` 最后,插入一条SNO为"001"、CNO为"001"、GRADE为80的记录到SC1表中: ``` INSERT INTO SC1 VALUES('001','001',80); ``` 这样,我们就验证了完整性规则是否正确。如果插入数据时违反了完整性约束,MySQL会报错并拒绝插入数据。 总结: 本次实验使用MySQL的Create Table命令创建了带有完整性约束的三个表,并通过数据更新对完整性规则进行了验证。在实际的数据库应用中,完整性约束是非常重要的,它可以保证数据的正确性和完整性,避免数据的不一致和错误。因此,在设计数据库时,我们需要充分考虑完整性约束的设置。

相关推荐

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

grpcio-1.63.0-cp38-cp38-linux_armv7l.whl

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

SQLyog-13.1.3-0.x86Community.exe

SQLyog-13.1.3-0.x86Community
recommend-type

VB自动出题题库系统设计(源代码+系统).rar

计算机专业毕业设计VB精品论文资源
recommend-type

debugpy-1.0.0b2-cp35-cp35m-manylinux1_i686.whl

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

实战自学python如何成为大佬(目录):https://blog.csdn.net/weixin-67859959/artic

实战自学python如何成为大佬(目录):https://blog.csdn.net/weixin-67859959/artic
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的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。