作业如下:
学生表: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;