目录
表结构
建表
插入数据
1、用SQL语句创建学生表student,定义主键,姓名不能重名,性别只能输入男或女,所在系的默认值是 “计算机”。
2、修改student 表中年龄(age)字段属性,数据类型由int 改变为smallint
3、为SC表建立按学号(sno)和课程号(cno)组合的升序的主键索引,索引名为SC_INDEX
4、 创建一视图 stu_info,查询全体学生的姓名,性别,课程名,成绩
练习:
学生表: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,查询全体学生的姓名,性别,课程名,成绩。
步骤:
学生表 Student
课程表 Course
学生选课表 SC
#建立student学生表
create table Student(
Sno int primary key unique key not null auto_increment,
Sname varchar(50) unique key,
Ssex varchar(10) check(Ssex='男' or Ssex='女') not null,
Sage int,
Sdept varchar(50) default '计算机'
);
#建立课程表
create table Course(
Cno int primary key unique key not null auto_increment,
Cname varchar(50)
);
#建立学生选课表
create table SC(
Sno int,
Cno int,
Score double,
primary key(Sno,Cno)
);
添加外键
#SC和student的外键
alter table SC add constraint Ssno foreign key(Sno) references Student(Sno);
#SC和Course的外键
alter table SC add constraint Ccno foreign key(Cno) references Course(Cno);
学生表:
INSERT INTO student(Sname,Ssex,Sage,Sdept)
VALUES('武大','男',18,'计算机'),
('孙二','女',20,'机械'),
('张三','男',17,'金融'),
('李四','女',18,'机械'),
('王五','男',18,'马克思'),
('赵六','男',18,'计算机'),
('钱七','女',18,'马克思'),
('刘八','男',20,'金融'),
('黄九','女',18,'计算机'),
('伍拾','男',21,'机械');
课程表:
INSERT INTO Course(Cno,Cname)
VALUES(1,'思政'),
(2,'工图'),
(3,'程序设计'),
(4,'高数'),
(5,'大英'),
(6,'大物'),
(7,'语文');
学生选课表:
insert into SC values(1,1,80),(1,2,81),(2,3,83),(2,4,84),(3,5,85),(3,6,86),(4,7,87);
alter table Student modify Sage smallint;
create index SC_INDEX on SC(Sno asc,Cno asc);
create view stu_info as select Student.Sname as '姓名',Student.Ssex as '性别',Course.Cname as '课程名',SC.Score as '成绩' from Student,Course,SC where Student.Sno=SC.Sno and Course.Cno=SC.Cno;