学生表:Student (Sno, Sname, Ssex , Sage, Sdept)
学号,姓名,性别,年龄,所在系 Sno为主键
课程表:Course (Cno, Cname)
课程号,课程名 Cno为主键
学生选课表:SC (Sno, Cno, Score)
学号,课程号,成绩 Sno,Cno为主键
用SQL语句创建学生表student,定义主键,姓名不能重名,性别只能输入男或女,所在系的默认值是 “计算机”。
CREATE TABLE `Student` (
`Sno` int NOT NULL,
`Sname` varchar(20) DEFAULT NULL,
`Ssex` varchar(4) DEFAULT NULL,
`Sage` int DEFAULT NULL,
`Sdept` varchar(20) DEFAULT '计算机',
PRIMARY KEY (`Sno`),
UNIQUE KEY `Sname` (`Sname`),
CONSTRAINT `Student_chk_1` CHECK ((`Ssex` in (_utf8mb4'男',_utf8mb4'女')))
)
2.修改student 表中年龄(age)字段属性,数据类型由int 改变为smallint。
alter table Student modify Sage smallint;
3.为SC表建立按学号(sno)和课程号(cno)组合的升序的主键索引,索引名为SC_INDEX 。
create index SC_no on Sc (Sno,Cno);
4.创建一视图 stu_info,查询全体学生的姓名,性别,课程名,成绩。
create view stu_info (姓名,性别,课程名,成绩) as select Student.`Sname`,Student.`Ssex`,Course.`Cname`,Sc.`Score` from Student,Course,Sc where Student.`Sno`=Sc.`Sno` and Course.`CCno`=Sc.`Cno`;