一、连接查询
1、交叉连接
就是从一张表的一条记录去连接另一张表中的所有记录,并且保存所有的记录,其中包括两个表的所有的字段!
从结果上看,就是对两张表做笛卡尔积!
笛卡尔积也就是两个表中所有可能的连接结果!如果第一张表有n1条记录,第二张表有n2条记录,那么笛卡尔积的结果有n1*n2条记录!
交叉连接语法:
select * | 字段列表 from 表1 cross join 表2
2、内连接
数据在左表中存在,同时在右表中又有对应的匹配的结果才会被保存。匹配得到才显示。如果没有匹配上,我们就认为数据没有意义,也就不会保存。
所谓的配合,就是存在某种条件使得两个或多个表之间能够识别彼此。通常就是两张表中存在相同的某个字段。表名一般很长,可以取一个别名。
select *|字段列表 from 左表 [inner] join 右表 on 左表.字段 = 右表.字段;
3、外连接
外连接又可以分成左外连接(left [outer] join)和右外连接(right [outer] join)。前者的左表为主表,后者的右表为主表。语法同内连接。
如果匹配成功,那么就保留两张表的所有的记录,如果匹配失败(也就是左表的一条记录无法匹配右表的所有的记录),此时,只保留左表的记录,右表的记录全部用null代替。
4、自然连接
只要两张表中具有相同的字段名,系统就认为是一个连接条件,就会主动的去匹配这两个相同的字段名的值是否相同,如果两个表的相同的字段名的值相同,就认为匹配成功;如果两张表中有多个字段名相同,则所有相同的字段名的值都要相同才算是匹配成功!
1)自然内连接
左表 natural inner join右表
自然内连接会主动的删除重复的一列而且将重复的那一列放在最前面
2)自然外连接
左表 natural left|right join 右表
二、子查询
所谓的子查询,从形式上看,就是一条select语句中又出现了一条或多条select语句。最基本的要求:所有的子查询都需要用括号括起来!
1、根据子查询返回值的形式
1)单 一 值 :也就是返回单行单列的子查询,也叫作标量子查询 //往往就是把标量子查询的结果当成一个值来使用,比如用来判断,参与运算等
2) 一 列 :也就是返回单列的子查询,也叫作列子查询 //列子查询的结果往往就是一系列相同属性的数据的集合,通常配合in和not in集合运算符来使用
3) 一 行 :返回一行的子查询就叫作行子查询
//在查询的过程中构造一个行元素才能与子查询的结果进行比较,select *|字段列表 from 表名 where(字段1,字段2……)=(行子查询结果)
4)多行多列:表子查询
//表子查询一般都是from型,也就是出现在from之后,一般当成一个数据源来使用,select *|字段列表 from 子查询结果 as 别名 where子句……
2、根据子查询出现的位置
from型:也就是子查询出现在from之后
where型:也就是子查询出现在where之后
exist型:判断是否查询到了结果
exists主要是用来做判断的,返回的结果是一个布尔值! select exists (子句);
判断依据:
如果子查询可以返回数据,那么exists的结果就是true,否则就是false
exists的主要作用就是判断后面的select语句有没有查询到数据
应用场景:
注册用户的时候,必须要保证用户名没有被注册过,此时可以先查询一下用户的用户名是否存在!