educoder 数据库原理与应用 实验六 约束与索引

数据结构说明

表结构如下:

学生表:Student

字段名 类型 主码 备注
Sno char(10) Y 学号
Sname varchar(20) 姓名
Ssex char(2) 性别
Sage smallint 年龄
Sdept varchar(20) 所在系

课程表:Course

字段名 类型 主码 备注
Cno char(10) Y 课程号
Cname varchar(20) 课程名
Cpno char(10) 先行课号
Ccredit smallint 课程学分

学生选课表:SC

字段名 类型 主码 备注
Sno char(10) Y 学号
Cno char(10) Y 课程号
Grade smallint 成绩

第1关:添加约束一

任务描述

本关任务:为表中的列添加约束

相关知识

使用SQL语句中的alter table语句。
SQL语句中关键字大小写不区分。
性别用’m’表示男,’f’表示女

实验完成要求

根据代码区的提示,将SQL语句书写在对应的代码区中。
注:请务必按要求为约束命名
1、为Student表的Sage列添加约束,使其取值小于30岁(约束名:stu_chk_sage)
2、为student表的Ssex列添加约束,使其只能取值‘m’或‘f’(约束名:stu_chk_ssex)
3、为Student表的ssex列添加缺省约束,缺省值为‘m’(约束名:stu_def_ssex)

测试说明
书写查询语句后,直接测试。

sql语句
sql1:

USE CS_yx_DB
GO
SET NOCOUNT ON

-- ********** Begin ********** --
-- ********** 此处写“1、为Student表的Sage列添加约束,使其取值小于30岁(约束名:stu_chk_sage)”的SQL语句 ********** --
alter table Student add constraint stu_chk_sage check(sage<30);
-- ********** End ********** --

GO
  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
数据库系统概论Sql练习表student、sc、course 数据库系统概论 数据库系统概论Sql 练习表 练习表student、 、sc、 、course。 。 先创建⼀个数据库 create database sql_test; //创建名为sql_test的数据库 创建三张表student、sc、course (1)student CREATE TABLE `student` ( `Sno` char(20) NOT NULL, `Sname` char(20) DEFAULT NULL, `Ssex` char(2) DEFAULT NULL, `Sage` smallint DEFAULT NULL, `Sdept` char(20) DEFAULT NULL, PRIMARY KEY (`Sno`), UNIQUE KEY `Sname` (`Sname`) ); //直接复制即可 (2)course CREATE TABLE `course` ( `Cno` char(4) NOT NULL, `Cname` char(40) NOT NULL, `Cpno` char(4) DEFAULT NULL, `Ccredit` smallint DEFAULT NULL, PRIMARY KEY (`Cno`), KEY `Cpno` (`Cpno`), CONSTRAINT `course_ibfk_1` FOREIGN KEY (`Cpno`) REFERENCES `course` (`Cno`) ); (3)sc CREATE TABLE `sc` ( `Sno` char(20) NOT NULL, `Cno` char(4) NOT NULL, `Grade` smallint DEFAULT NULL, PRIMARY KEY (`Sno`,`Cno`), KEY `Cno` (`Cno`), CONSTRAINT `sc_ibfk_1` FOREIGN KEY (`Sno`) REFERENCES `student` (`Sno`), CONSTRAINT `sc_ibfk_2` FOREIGN KEY (`Cno`) REFERENCES `course` (`Cno`) ); 插⼊数据 (1)student INSERT INTO `student` VALUES ('201215121', '李勇', '男', 20, 'CS'); INSERT INTO `student` VALUES ('201215122', '刘晨', '⼥', 19, 'CS'); INSERT INTO `student` VALUES ('201215123', '王敏', '⼥', 19, 'MA'); INSERT INTO `student` VALUES ('201215125', '张⽴', '男', 19, 'IS'); (2)course insert into COURSE(Cno,Cname)values('1','数据库'); insert into COURSE(Cno,Cname)values('2','数学'); insert into COURSE(Cno,Cname)values('3','信息系统'); insert into COURSE(Cno,Cname)values('4','操作系统'); insert into COURSE(Cno,Cname)values('5','数据结构'); insert into COURSE(Cno,Cname)values('6','数据处理'); insert into COURSE(Cno,Cname)values('7','PASCAL语⾔'); //先插⼊第⼀段,因为参照完整性规则此表含有student表的外键不能⼀次性插⼊ update COURSE set Cpno='5',Ccredit = 4 where Cno = '1'; update COURSE set Cpno='4',Ccredit = 2 where Cno = '2'; update COURSE set Cpno='1',Ccredit = 4 where Cno = '3'; update COURSE set Cpno='6',Ccredit = 3 where Cno = '4'; update COURSE set Cpno='7',Ccredit = 4 where Cno = '5'; update COURSE set Cpno='5',Ccredit = 2 where Cno = '6'; update COURSE set Cpno=
数据库原理应用》是由钱雪忠编著的一本介绍数据库原理应用的教材。该教材主要分为两个部分:数据库原理数据库应用。 在数据库原理部分,该书首先介绍了数据库的基本概念,包括数据、数据库数据库管理系统等;然后详细讲解了数据库模型和数据库管理系统的基本原理,包括系模型、系代数与系演算、数据库设计和规范化等;接着介绍了数据库的事务管理和并发控制,包括事务的特性、事务的隔离级别、并发控制的基本概念和方法等;最后介绍了数据库的安全性和完整性,包括数据库的权限管理、数据加密和恢复等。 在数据库应用部分,该书介绍了数据库的基本操作语言SQL,包括SQL的基本语法、数据查询、数据更新操作等;然后介绍了数据库的高级应用,包括视图、索引、触发器、存储过程和函数等;接着介绍了数据库的分布式数据库和数据仓库,包括分布式数据库的概念和体系结构、数据仓库的概念和构建等;最后介绍了面向对象数据库和NoSQL数据库的基本原理应用。 该教材以简明易懂的语言、清晰的结构和丰富的例子来讲解数据库原理应用,能够帮助读者全面理解数据库的基本概念和原理,掌握数据库的基本操作和高级应用,提升数据库的设计和管理能力。同时,该教材还附有大量习题和实践案例,帮助读者巩固知识、拓展思维,培养解决实际问题的能力。因此,该教材是学习和应用数据库的重要参考资料。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xingcheng--dp

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值