交叉连接返回的结果是被连接的两个表中所有数据行的笛卡儿积;
比如:在集合 A={a,b} 和集合 B={0,1,2}中,集合A和B的笛卡尔积为{(a,0),(a,1),(a,2),(b,0),(b,1),
(b,2)}。所以,交叉连接也被称为笛卡尔连接,其语法格式如下:
select * from 左表 , 右表
select * from 左表 cross join 右表
在该语法中:cross join 用于连接两个要查询的表,通过该语句可以查询两个表中所有的数据组
合。【了解即可,基本用不到】
内连接 (Inner Join) 又称简单连接或自然连接,是一种非常常见的连接查询,内连接查询可以查询
两张或两张以上的表。
内连接使用比较运算符对两个表中的数据进行比较并列出与连接条件匹配的数据行,组合成新的记
录。
也就是说在内连接查询中只有满足条件的记录才能出现在查询结果中。其语法格式如下:
select * from 左表 inner join 右表 on 左右表关联字段
select * from 左表 , 右表 where 条件
select 字段1,字段2, ... from 左表 inner join 右表 on 左表.关系字段= 右表.关系字段
在该语法中:inner join 用于连接两个表,on 来指定连接条件;其中 inner 可以省略。
-- 若存在数据库mydb则删除
drop database if exists test;
-- 创建数据库test
create database test;
-- 选择数据库test
USE test;
-- 创建班级表
create table class(
id int (4) NOT NULL PRIMARY KEY,
name varchar(20)
);
-- 创建学生表
create table student(
stuid int (4) NOT NULL PRIMARY KEY,
stuname varchar (20),
age int (2),
studentid int (4) NOT NULL
);
-- 向班级表插入数据
insert into class values(1001,'JAVA');
insert into class values(1002,'Python');
insert into class values(1003,'MySQL');
insert into class values(1004,'C++');
-- 向学生表插入数据
insert into student values(1,'张三',19,1003);
insert into student values(2,'李四',18,1002);
insert into student values(3,'王五',20,1001);
insert into student values(4,'赵六',20,1004);
查询学生姓名及其学生所学课程名称:
# 方法一:
select class.name,student.stuname from student inner join class on class.id=student.studentid;
# 方法二:
select class.name,student.stuname from student,class where class.id=student.studentid;
在使用内连接查询时我们发现:
返回的结果只包含符合查询条件和连接条件的数据。但是,有时还需要在返回查询结果中不仅
包含符合条件的数据,而且还包括左表、右表或两个表中的所有数据,此时我们就需要使用外连接
查询。外连接又分为左(外)连接和右(外)连接。
# 1. 左外
select * from 左表 left join 右表 on 左右表关联字段
# 2. 右外
select * from 左表 right join 右表 on 左右表关联字段
left 【outer】join: 左外连接(左连接), 以左表为主表
select 字段1,字段2, ... FROM 左表 left [outer] join 右表 ON 左表.字段=右表.字段 WHERE 条件
[outer] 可省略
right 【outer】join: 右外连接(右连接), 以右表为主表
select 字段1,字段2, ... FROM 左表 right [outer] join 右表 ON 左表.字段=右表.字段 WHERE 条件
[outer] 可省略
由此可见,外连接的语法格式和内连接非常相似,只不过使用的是left 【outer】join、right
【outer】join关键字。其中,关键字左边的表被称为左表,关键字右边的表被称为右表;outer可
以省略。
在使用左(外)连接和右(外)连接查询时,查询结果是不一致的,具体如下:
1、left 【outer】join 左(外)连接:返回包括左表中的所有记录和右表中符合连接条件的记录;
如果左表的某条记录在右表中不存在则在右表中显示为空。
2、right 【outer】join 右(外)连接:返回包括右表中的所有记录和左表中符合连接条件的记录;
如果右表的某条记录在左表中不存在则在右表中显示为空。
-- 若存在数据库mydb则删除
drop database if exists test;
-- 创建数据库test
create database test;
-- 选择数据库test
USE test;
-- 创建班级表
create table class(
id int (4) NOT NULL PRIMARY KEY,
name varchar(20)
);
-- 创建学生表
create table student(
stuid int (4) NOT NULL PRIMARY KEY,
stuname varchar (20),
age int (2),
studentid int (4) NOT NULL
);
-- 向班级表插入数据
insert into class values(1001,'JAVA');
insert into class values(1002,'C++');
insert into class values(1003,'Python');
insert into class values(1004,'PHP');
-- 向学生表插入数据
insert into student values(1,'张三',19,1003);
insert into student values(2,'李四',18,1002);
insert into student values(3,'王五',20,1001);
insert into student values(4,'赵六',20,1004);;
3.1 左(外)连接查询
查询每个班的班级ID、班级名称及该班的所有学生的名字 :
select class.id,class.name,student.stuname from class left outer join student on class.id=student.studentid;
查询每个班的班级ID、班级名称及该班的所有学生的名字 :
select class.id,class.name,student.stuname from class right outer join student on class.cid=student.studentid;