通过查询多张表,用连接查询进行多表联合查询
关键字:inner join 内连接
left join 左连接
right join 右连接
create database db_test2;
use db_test2;
create table 表名(字段名1,字段名2,......);
create table classes(
class_id int primary key auto_increment,#主键自增
class_name varchar(40) not null unique,
class_remark varchar(200)
);
create table 表名(字段名1,字段名2,......);
create table students(
stu_num char(8) primary key ,
stu_name varchar(20) not null,
stu_gender char(2) not null,
stu_age int not null,
cid int,
constraint FK_STUDENTS_CLASSES foreign key(cid)
references classes(class_id)
on update cascade ON DELETE CASCADE
);
insert into 表名 (字段名)values(添加的数据);
insert into classes (class_name,class_remark)values('Java2204','......');
insert into classes (class_name,class_remark)values('Java2205','......');
insert into classes (class_name,class_remark)values('Java2206','......');
insert into classes (class_name,class_remark)values('Python','......');
以下三个信息,属于class_id=1 的班级 (Java2204)
insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220101','张三','男',20,1);
insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220102','李四','女',20,1);
insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220103','王五','男',20,1);
以下两个学生信息,属于class_id=2 的班级 (Java2205)
insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220104','赵婷','女',20,1);
insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220105','孙七','男',20,2);
小红和小明没有设置班级信息
insert into students (stu_num,stu_name,stu_gender,stu_age)
values('20220106','小红','女',20);
insert into students (stu_num,stu_name,stu_gender,stu_age)
values('20220107','小明','男',20);
select * from students s ;
select * from classes c ;
select ...... from 表名1 inner join 表名2 on 匹配条件 [where 条件];
经过内连接(表连接)之后,将两张表的数据以笛卡尔积的效果进行连接
select * from 表名1 inner join 表名2;
select * from students inner join classes;
产生笛卡尔积,效果如下,将表1中的每个数据与第二个表中的每个数据都进行匹配
7 * 3 = 28,共有28个数据
消除笛卡尔积,在前缀后加上 on 匹配条件 [where 条件];
select ...... from 表名1 inner join 表名2 on 匹配条件 [where 条件];
内连接条件
两张表使用inner join连接查询之后生产的笛卡尔积数据中很多数据都是无意义的,我们如何消除无意义的数据呢?——添加两张进行连接查询时的匹配条件
使用 on 设置两张表连接查询时的匹配条件
使用where进行两个表之间的连接
select * from students inner join classes where students.cid=classes.class_id ;
使用on进行两个表之间的连接
select * from students inner join classes on students.cid=classes.class_id ;
on筛选:先进行判断连接条件是否成立,如果成立后,再会进行组合,就不会有笛卡尔积的结果
左连接显示左表中的所有数据,如果在右表中存在与左表记录满足匹配条件的数据,则进行匹配,如果右表中不存在匹配数据,则显示为NULL;
select * from 左表名 left join 右表名 on 匹配条件 [where 条件];
左连接:显示左表中的所有记录
请查询出所有学生信息,如果有学生有对应的班级信息,则将对应的班级信息也查询出来
select * from students left join classes on students.cid=classes.class_id ;
右连接显示右表中的所有数据,如果在左表中存在与右表记录满足匹配条件的数据,则进行匹配,如果左表中不存在匹配数据,则显示为NULL;
select * from 表名1 RIGHT JOIN 表名2 ON 表名1与表名2的关联字符;
右连接:显示右表中的所有记录
将右表中的所有数据显示出来
select * from students right join classes on students.cid=classes.class_id ;
内连接:只会显示出两表中有关联的数据
左连接:显示出左表中的所有数据,右表中只写有关联的数据
右连接:显示出右表中的所有数据,左表中只写有关联的数据
alter table 表名 rename column 列名 to 新列名;
修改列名
alter table students rename column stu_name to name;
alter table classes rename column class_name to name;
select students.name,classes.name from students inner join classes on students.cid = classes.class_id ;
select s.name,c.name from students s inner join classes c on s.cid=c.class_id ;
子查询——先进行一次查询,第一次查询的结果作为第二次查询的源/条件(第二次查询是基于第一次的查询结果来进行的)
查询班级表中字段名为Java2204的数据, 查询所有Java2204班级中选课副码为1的学生信息
查询班级表中字段名为Java2204的数据
select class_id from classes c where name ='Java2204';
查询所有Java2204班级中选课副码为1的学生信息
select * from students s where cid=1;
select class_id from classes c where name like 'Java%' ;
#显示三条查询语句 union连接关键字
select * from students s where cid=1
union
select * from students s where cid=2
union
select * from students s where cid=3;
如果查询结果是单列多行,要有关键字in
in代表的是包含,not in代表不包含
select * from students s where cid in(select class_id from classes c where name like 'Java%');
select * from (select * from 表名 where 限制) 别名 where 别名.列名 = 限制;
将第一步查询语句当作一个虚拟表(限制信息)查询第二个表
select * from (select * from students where cid = 1) t where t.stu_gender='男';