关于索引和约束作业

作业如下:

学生表:Student (Sno, Sname, Ssex , Sage, Sdept)
学号,姓名,性别,年龄,所在系 Sno为主键
课程表:Course (Cno, Cname,)
课程号,课程名 Cno为主键
学生选课表:SC (Sno, Cno, Score)
学号,课程号,成绩 Sno,Cno为主键

1.用SQL语句创建学生表student,定义主键,姓名不能重名,性别只能输入男或女,所在系的默认值是 “计算机”。
2.修改student 表中年龄(age)字段属性,数据类型由int 改变为smallint。
3.为SC表建立按学号(sno)和课程号(cno)组合的升序的主键索引,索引名为SC_INDEX 。
4.创建一视图 stu_info,查询全体学生的姓名,性别,课程名,成绩。

注意:中文不能用作创建表时别名

Create table Student(
    Sno varchar(100),
    Sname varchar(100),
    Ssex varchar(20),
    Sage int,
    Sdept VARCHAR(100)
)ENGINE=INNODB charset=utf8;
ALTER TABLE Student ADD CONSTRAINT PK_Sno PRIMARY KEY(Sno);
ALTER TABLE Student ADD CONSTRAINT UNIQUE(Sname);

# 注意检查约束在8.0之前,MySQL默认但不会强制的遵循check约束(写不报错,但是不生效,需要通触发器完成)
ALTER TABLE Student ADD CONSTRAINT CHECK(Ssex in('男','女'));

#注意写默认值时不要用"="符号或者直接小括号里面填写值
ALTER TABLE Student CHANGE Sdept Sdept VARCHAR(100) DEFAULT '计算机';

#在改变此字段类型时必须将表字符集改为utf-8
ALTER TABLE Student MODIFY Sage SMALLINT;
CREATE TABLE Course(
Cno INT PRIMARY KEY,
Cname VARCHAR(100)
)ENGINE=INNODB CHARSET=utf8;
CREATE TABLE Sc(
Sno INT PRIMARY KEY,
Cno INT,
Score INT
)ENGINE=INNODB CHARSET=utf8;

#主键索引此处用primary key会报错,但是我理解主键是唯一的,所以用了唯一索引代替
create UNIQUE index SC_INDEX on Sc(Sno ASC,Cno ASC);

#VIEW后面跟值是不能是中文,英文必须是后面select后面的值
CREATE VIEW stu_info AS SELECT Sname,Ssex,Cname,Score FROM Student,Sc,Course WHERE Student.Sno=sc.Sno AND Course.Cno=Sc.Cno;

你可能感兴趣的:(数据库,sql)