MySQL像其他语言一样,也提供了很多库函数,分为单行函数和分组函数(聚合函数),我们这里先简易介绍一些函数,熟悉就行,知道怎么使用即可.
?
?
注:LPAD函数是右对齐,RPAD函数是左对齐
注:如果为表起了别名,就不能使用表的原名了
多表查询的实现一共有SQL92和SQL99两种语法方式.至于为什么需要多表查询呢?
由于我们在实现业务的时候将不同的表分开会提高我们的查询效率,
我们这里用七张来描述两张表的关系
其中最下面两张表是由上面的表组合产生的
内连接
中图是表示内连接的图,只包含两张图的数据都不为空的情况
eg:在两张表中查询员工姓名和奖金? 使用内连接查询就不会查到没有姓名的奖金或没有奖金的员工
//SQL92语法 SELECT 字段 FROM 表a,表b WHERE 连接条件; //SQL99语法 SELECT 字段 FROM 表a JOIN 表b ON 连接条件;
外连接
左外连接(左上图)
需求: 假设我需要查询到所有员工的奖金情况,包含没有奖金的也需要显示记录,此时就可以使用左外连接
注:MySQL不支持SQL92语法中左外连接
//SQL92语法 SELECT 字段 FROM 表a,表b WHERE a.id = b.id(+); 数据少的那一方放一个+即可 //SQL99语法 SELECT 字段 FROM 表a(员工表) LEFT JOIN 表b ON 连接条件;
右外连接(右上图)
和上面类似
//SQL92语法 SELECT 字段 FROM 表a,表b WHERE a.id(+) = b.id; 数据少的那一方放一个+即可 //SQL99语法 SELECT 字段 FROM 表a(员工表) RIGHT JOIN 表b ON 连接条件;
左中图
SELECT 字段 FROM 表a(员工表) RIGHT JOIN 表b ON 连接条件 WHERE b.data IS NULL;
右中图
SELECT 字段 FROM 表a(员工表) RIGHT JOIN 表b ON 连接条件 WHERE a.data IS NULL;
UNION关键字的使用
作用:将两个查询到的结果集结合到一起,要求是对应列的数据类型相同.
SQL中的UNION操作符告诉数据库将通过单独的SELECT查询检索到的两个单独的结果集合并为一个结果集,其中包含两个查询返回的行。
注意:数据库不会限制UNION中SELECT查询的复杂性。数据检索查询可以包括JOIN语句、聚合或子查询。通常,UNION用于合并复杂语句的结果。
?注:不建议使用 union ,因为 union操作设计去重操作,会加大开销,建议使用 union all 操作
满外连接(左下图)
//SQL99 SELECT 字段 FROM 表a(员工表) FULL JOIN 表b ON 连接条件; //SQL92 LEFT JOIN 的语句 UNION ALL b.data IS NULL;
下面几个图都是一样的,不做过多赘述
自然连接
(natural join) 可以自动识别两个表相同字段的列做连接
自动识别连接条件
SELECT 字段 FROM 表a(员工表) NATURAL JOIN 表b ;
using(和join配合使用)
SELECT 字段 FROM 表a(员工表) FULL JOIN 表b USING(连接条件);
?