MySQL中的连接查询(等值连接)

 更新时间:2022年07月20日 10:40:27   投稿:jingxian  
这篇文章主要介绍了MySQL中的连接查询(等值连接),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

1. 笛卡尔乘积

表1有m行数据,表2有n行数据,查询结果有m*n行数据。

2. 分类

(1)按年代分类

sql92标准:仅支持内连接

sql99标准(推荐):支持内连接、外连接(左外连接和右外连接)、交叉连接

(2)按功能分类

内连接:等值连接、非等值连接、自连接

外连接:左外连接、右外连接、全外连接

交叉连接

3. 等值连接

(1)查询女生名及其对应的男朋友名

SELECT 
    girlname,
    boyname
FROM
    boys,
    girls
WHERE
    girls.boyfriend_id=boys.girlfriend_id;

(2)查询员工名(last_name)和对应的部门名(department_name)-------------(根据关联的id查询)

SELECT 
    last_name,
    department_name
FROM
    JDSC,
    SNSC
WHERE
    JDSC.`id`=SNSC.`id`;

(3)查询员工名(last_name)、工种号(job_id)、工种名(job_title) (员工表:JDSC  工作表:JOBSC)------为表起别名,提升简洁度,避免歧义

#"e.job_id"是为了避免歧义
SELECT
    last_name,
    e.job_id,
    job_title
FROM
    ESC e,
    JOBSC j
WHERE
    e.`job_id`=j.`job_id`;

注意:

如果为表起了别名,则查询的字段不能使用原来的表名去限定。

上述两个表的顺序可互换

(4)查询有奖金的员工名、部门名

#员工名:last_name
#部门名:department_name
#奖金率:commissiom_pct
SELECT
    last_name,
    department_name,
    commissiom_pct
FROM
    employees e,
    department d
WHERE
    e.`department_id`=d.`department_id`
AND
    e.`commissiom_pct` IS NOT NULL;

(5)分组查询——查询每个城市的部门个数

#城市分组表名:city
#部门分组表名:departments 
SELECT
    COUNT(*) 个数,
    city
FROM
    departments d,
    locations l
WHERE
    d.`location_id`=l.`location_id`
GROUP BY
    city;

(6)排序——查询每个工种的工种名和员工个数,并按员工个数降序

SELECT 
    job_title,
    COUNT(*)
FROM
    emloyees e,
    jobs j
WHERE
    e.`job_id`=j.`job_id`
GROUP BY
    job_title
ORDER BY
    COUNT(*) DESC;

(7)三表连接——查询员工名、部门名和所在的城市

SELECT
    last_name,
    department_name,
    city
FROM
    employees e,
    departments d,
    locations l
WHERE
    e.`department_id`=d.`department_id`
AND
    d.`location_id`=l.`location_id`
AND 
    city LIKE 's%';

4. 总结

1)多表等值连接的结果为多表的交集部分

2)m表连接,至少需要n-1个连接条件

3)多表的顺序没有要求

4)一般需要为表起别名

5)可以搭配所有子句使用,例如排序、分组、筛选

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 这种sql写法真的会导致索引失效吗

    这种sql写法真的会导致索引失效吗

    这篇文章主要给大家介绍了关于网上流传的某种sql写法会导致索引失效的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用sql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • MySQL的mysqldump工具用法详解

    MySQL的mysqldump工具用法详解

    这篇文章主要介绍了MySQL的mysqldump工具用法详解,同时附带了相关Source命令的用法,详解需要的朋友可以参考下
    2015-07-07
  • CentOS6.9+Mysql5.7.18源码安装详细教程

    CentOS6.9+Mysql5.7.18源码安装详细教程

    CentOS6.9+Mysql5.7.18源码安装,以下操作均在root用户下执行。下面通过本教程给大家详细介绍CentOS6.9+Mysql5.7.18源码安装方法,需要的的朋友参考下吧
    2017-06-06
  • MySQL性能优化的最佳20+条经验

    MySQL性能优化的最佳20+条经验

    这篇文章主要为大家详细介绍了MySQL性能优化的最佳20+条经验,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 使用mysql中遇到的几个问题

    使用mysql中遇到的几个问题

    首先mysql不是可视化的,可以通过命令行进行操作,包括创建数据库、表、添加数据等等。那岂不是很不方便了吗?
    2009-07-07
  • 在SpringBoot中实现WebSocket会话管理的方案

    在SpringBoot中实现WebSocket会话管理的方案

    在构建实时通信应用时,WebSocket 无疑是一个强大的工具,SpringBoot提供了对WebSocket的支持,本文旨在探讨如何在 Spring Boot 应用中实现 WebSocket 会话管理,我们将通过一个模拟的场景一步步展开讨论,需要的朋友可以参考下
    2023-11-11
  • 分析Mysql表读写、索引等操作的sql语句效率优化问题

    分析Mysql表读写、索引等操作的sql语句效率优化问题

    今天小编就为大家分享一篇关于分析Mysql表读写、索引等操作的sql语句效率优化问题,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • MySQL中的BETWEEN...AND的使用情况

    MySQL中的BETWEEN...AND的使用情况

    这篇文章主要介绍了MySQL中的BETWEEN...AND的使用情况,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 关于SQL建表语句使用详解

    关于SQL建表语句使用详解

    在SQL数据库设计中,创建表是基本操作,涉及定义表结构,包括列名、数据类型和约束等,本文详细介绍建表语句,通过示例帮助理解,常见数据类型包括整数、浮点数、字符串、日期时间等,约束确保数据完整性,包括主键、唯一、非空、默认值、外键和检查约束
    2024-10-10
  • MySQL提高分页效率

    MySQL提高分页效率

    本文分享的这段代码是大数据量时提高分页的效率的测试代码,感兴趣的小伙伴可以参考一下
    2015-10-10

最新评论