MySQl 连接查询 二 ——99标准

二,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是西安连接条件和筛选条件的分离


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

§九千七§

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值