MySQL数据库练习

目录

表结构

建表

插入数据

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);

MySQL数据库练习_第1张图片MySQL数据库练习_第2张图片MySQL数据库练习_第3张图片

 

1、用SQL语句创建学生表student,定义主键,姓名不能重名,性别只能输入男或女,所在系的默认值是 “计算机”。

MySQL数据库练习_第4张图片

2、修改student 表中年龄(age)字段属性,数据类型由int 改变为smallint

alter table Student modify Sage smallint;

MySQL数据库练习_第5张图片

 3、为SC表建立按学号(sno)和课程号(cno)组合的升序的主键索引,索引名为SC_INDEX

create index SC_INDEX on SC(Sno asc,Cno asc);

MySQL数据库练习_第6张图片

4、 创建一视图 stu_info,查询全体学生的姓名,性别,课程名,成绩

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;

 

你可能感兴趣的:(DateBase,数据库,mysql,windows)