二,sql 99语法
语法:
select 查询列表
from 表1 别名 【连接类型】
join 表2 别名
on 连接条件
【where 筛选条件】
【group by 分组】
【having 筛选条件】
【order by 排序列表】
分类
内连接 * inner
语法: select 查询表名
from 表1 别名
inner join 表2 别名
on 连接条件
分类
等值连接
非等值连接
自链接
特点:
1,添加排序,分组,筛选
2,inner 可以省略
3,筛选条件放where 后面,连接条件放on后面,提高分离性,便于阅读
4,inner join 连接和sql 92中的等职连接效果是一样的,都是查询多表的交集
外连接
左外 * left 【outer】
右外 * right 【outer】
全外 full 【outer】
交叉连接 cross
一,等值连接
案例1.查询员工名,部门名
SELECT last_name,department_name
FROM employees e
INNER JOIN departments d
ON e.`department_id`=d.`department_id`;
案例2.查询名字中包含e的员工名和工种名(添加筛选)
SELECT last_name,job_title
FROM employees e
JOIN jobs j
ON e.`job_id`=j.`job_id`
WHERE e.last_name LIKE '%e%';
案例3.查询部门个数>3的城市名和部门个数(添加分组+筛选)
SELECT COUNT(*) 部门个数,city
FROM locations l
INNER JOIN departments d
ON l.`location_id`=d.`location_id`
GROUP BY city
HAVING COUNT(*)>3;
案例4.查询哪个部门的员工数>3的部门名和员工个数,并按个数降序(添加排序)
SELECT department_name,COUNT(*)
FROM departments d
INNER JOIN employees e
ON d.`department_id`=e.`department_id`
GROUP BY department_name
HAVING COUNT(*)>3
ORDER BY COUNT(*) DESC;
案例5.查询员工名,部门名,工种名,并按部门名降序(多表查询)
SELECT last_name,job_title,department_name
FROM employees e
INNER JOIN jobs j
ON e.`job_id`=e.`job_id`
INNER JOIN departments d
ON d.`department_id`=e.`department_id`
ORDER BY department_name DESC;
二,非等值连接
查询员工工资级别
SELECT salary,grade_level
FROM employees e
JOIN job_grades g
ON e.salary BETWEEN g.`lowest_sal` AND g.`highest_sal`;
查询每个工资级别的个数>2,并且按工资级别降序排序
SELECT grade_level,COUNT(*)
FROM employees e
JOIN job_grades g
ON e.`salary` BETWEEN g.`lowest_sal` AND g.`highest_sal`
GROUP BY grade_level
HAVING COUNT(*)>7
ORDER BY grade_level DESC;
三,自连接
查询员工的名字,上级的名字
SELECT e.last_name 上级名字,m.last_name 员工名字
FROM employees e
INNER JOIN employees m
ON e.`employee_id`=m.`manager_id`;
外连接
应用场景:查询一个表中有,另一个表没有的记录
特点:
1.外连接的查询结果为主表中的所有记录
如果从表中有和它匹配的,则显示匹配的值
如果从表中没有和它匹配的,则显示null
外连接查询的结果= 内连接结果 + 主表中有而从表没有的记录
2.左外连接, left join 左边的是主表
右外连接,right join 右边是主表
3.左外和右外交换两个表的顺序,可以实现同样的效果
4.全外连接 = 内连接 + 表1有表2没有的 + 表2有表1没有的
引入:查询男朋友 不在男神表的女神名
左/右外连接
SELECT b.name,bo.*
FROM beauty b
LEFT OUTER JOIN boys bo
ON b.`boyfriend_id`=bo.`id`;
全外连接
USE girls;
SELECT b.*,bo.*
FROM beauty b
FULL OUTER JOIN boys bo
ON b.`boyfriend_id`=bo.id;
交叉连接
结果为笛卡尔乘积得到的数据
SELECT b.*,bo.*
FROM beauty b
CROSS JOIN boys bo;
sql 92 99
功能:sql 99支持的较多
可读性:sql 99是西安连接条件和筛选条件的分离