连接
连接是在多个表之间通过一定的连接条件,使表之间发生关联,进而能从多个表之间获取数据。
在 WHERE子句中书写连接条件。
如果在多个表中出现相同的列名,则需要使用表名作为来自该表的列名的前缀。
N个表相连时,至少需要N-1个连接条件。
第七天(2018/8/1)
日期时间函数
流程控制函数
– CASE
– IF
– IFNULL
– NULLIF
WHEN 2 THEN ‘two‘ ELSE ‘more‘ END;
– 如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。
– IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。
– SELECT IF(1>2,2,3);
– 假如expr1 不为NULL ,则IFNULL() 的返回值为expr1 ; 否则其返回值为expr2 。
– IFNULL() 的返回值是数字或是字符串,具体情况取决于其所使用的语境
多表查询
– 第一个表中的所有行和第二个表中的所有行都发生连接。
– 连接条件被省略
– 连接条件是无效的
等值连接
用等于号的形式进行多表的连接
例:SELECT ENAME,DNAME,LOC
FROM EMP,DEPT
WHERE EMP.DEPTNO = DEPT.DEPTNO
限制歧义列名
非等值连接
用不等号的形式进行多表连接
例:SELECT ENAME,SAL,GRADE
FROM EMP,SALGRADE
WHERE SAL >= LOSAL
AND SAL <= HISAL
自连接
自身连接,也叫自连接,是一个表通过某种条件和本身进行连接的一种方式,就如同多个表连接一样
SELECT T1.ENAME 员工姓名,T2.ENAME 上级姓名
FROM EMP T1,EMP T2
WHERE T1.MGR = T2.EMPNO
ANSI SQL:1999标准的连接语法
交叉连接
交叉连接会产生连个表的交叉乘积,和两个表之间的笛卡尔积是一样的;
使用CROSS JOIN 子句完成
例:
SELECT *
FROM EMP
CROSS JOIN DEPT
自然连接
自然连接是对两个表之间相同名字和数据类型的列进行的等值连接;
如果两个表之间相同名称的列的数据类型不同,则会产生错误;
使用NATURAL JOIN子句来完成
例:
SELECT *
FROM EMP
NATURAL JOIN DEPT
USING子句
自然连接是使用所有名称和数据类型相匹配的列作为连接条件,而USING子句可以指定用某个或某几个相同名字和数据类型的列作为连接条件。
例:
SELECT ENAME,DNAME,LOC
FROM EMP
JOIN DEPT
USING (DEPTNO)
注:
如果有若干个列名称相同但数据类型不同,自然连接子句可以用USING子句来替换,以指定产生等值连接的列。
如果有多于一个列都匹配的情况,使用USING子句只能指定其中的一列。
USING子句中的用到的列不能使用表名和别名作为前缀。
NATURAL JOIN子句和USING子句是相互排斥的,不能同时使用
ON子句
自然连接条件基本上是具有相同列名的表之间的等值连接;
如果要指定任意连接条件,或指定要连接的列,则可以使用ON子句;
用ON将连接条件和其它检索条件分隔开,其它检索条件写在WHERE子句;
ON子句可以提高代码的可读性。
例:
SELECT *
FROM EMP
JOIN DEPT
ON EMP.DEPTNO = DEPT.DEPTNO
JOIN SALGRADE
ON SAL BETWEEN LOSAL AND HISAL
左外连接
左外连接以FROM子句中的左边表为基表,该表所有行数据按照连接条件无论是否与右边表能匹配上,都会被显示出来。
SELECT *
FROM DEPT -- 哪张表需要全部显示哪张表就是主表,写在前面
LEFT JOIN EMP
ON DEPT.DEPTNO = EMP.DEPTNO
原文:https://www.cnblogs.com/makangning/p/9403664.html