数据库视图
学生表:Student (Sno, Sname, Ssex , Sage, Sdept)
学号,姓名,性别,年龄,所在系 Sno为主键
students | CREATE TABLE `students` (
`Sno` int NOT NULL,
`Sname` char(30) DEFAULT NULL,
`Ssex` char(10) DEFAULT NULL,
`Sage` int DEFAULT NULL,
`Sdept` char(20) DEFAULT '计算机',
PRIMARY KEY (`Sno`),
UNIQUE KEY `Sname` (`Sname`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4
课程表:Course (Cno, Cname,)
课程号,课程名 Cno为主键
CREATE TABLE `course` (
`Cno` int NOT NULL,
`Cname` char(20) DEFAULT NULL,
PRIMARY KEY (`Cno`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4
学生选课表:SC (Sno, Cno, Score)
学号,课程号,成绩 Sno,Cno为主键
CREATE TABLE `sc` (
`Sno` int DEFAULT NULL,
`Cno` int NOT NULL,
`Score` char(10) DEFAULT NULL,
PRIMARY KEY (`Cno`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4
1.用SQL语句创建学生表student,定义主键,姓名不能重名,性别只能输入男或女,所在系的默认值是 “计算机”。
`Sdept` char(20) DEFAULT '计算机', -- 默认计算机
PRIMARY KEY (`Sno`),-- 主键
UNIQUE KEY `Sname` (`Sname`),-- 不许重复
2.修改student 表中年龄(age)字段属性,数据类型由int 改变为smallint。
alter table students modify Sage smallint;
3.为SC表建立按学号(sno)和课程号(cno)组合的升序的主键索引,索引名为SC_INDEX 。
create index SC_INDEX on SC(Sno,Cno asc);
4.创建一视图 stu_info,查询全体学生的姓名,性别,课程名,成绩。
create view stu_info
as select Sname,Ssex,Cname,Score from students,Course,SC
where students.Sno=SC.Sno and SC.Cno=Course.Cno;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步