SQL99中的natural join 和 using

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: natural join 叫自然连接,是SQL99语法中支持的一种连接方式,mysql与oracle等主流数据库均支持这种语法。natural join 无需声明连接条件,sql执行器会自动寻找连接的两个表中相同的字段去生成连接条件,然后取数据的交集。

一、natural join 是什么



natural join 叫自然连接,是SQL99语法中支持的一种连接方式,mysql与oracle等主流数据库均支持这种语法。natural join 无需声明连接条件,sql执行器会自动寻找连接的两个表中相同的字段去生成连接条件,然后取数据的交集。


其实自然连接就是自动生成连接条件的内连接而已。他也不是什么新的连接,就是一个为了简化写法的语法糖而已(mysql中)。我们可以用下面的sql来证明下这个连接到底是怎么执行的。


原始sql:

select a.user_id from sys_user  a 
natural join sys_user_role ;


sql执行器优化真正执行的sql:

select `sunacwy_cockpit`.`a`.`user_id` AS `user_id` from `sunacwy_cockpit`.`sys_user` `a` 
join `sunacwy_cockpit`.`sys_user_role` where (`sunacwy_cockpit`.`a`.`user_id` = `sunacwy_cockpit`.`sys_user_role`.`user_id`)


从上面的例子中我们可以看到,当写出了自然连接时,真正执行的还是内连接的sql,只不过是省略了连接条件的书写而已。上面的自然连接的sql我们完全可以视作如下的sql:

select a.user_id from sys_user  a 
inner join sys_user_role b on a.user_id = b. user_id;


不过使用内连接必须有个前提条件,两个表的连接字段必须是同名的,这样才能正常使用自然连接。


二、using是什么



先看下下面三个意思完全一致的sql,就会明白usring是什么了。


sql一:

select a.user_id from sys_user  a 
inner join sys_user_role b on a.user_id = b. user_id;


sql二:

select a.user_id from sys_user   
inner join sys_user_role using(user_id);


sql三:

select a.user_id from sys_user   
natural join sys_user_role;


这样应该很直观就可以看出usring是干什么的了,usring()里面的字段就是连接条件,其实using在mysql中也是一个语法糖而已,sql执行优化器还是会把他翻译成where条件或者on条件的,此外using使用也是要求连接字段必须在两个表中同名才行。


三、总结natural join 和 using



其实无论是natural join 还是 using在mysql中都不是一个新的东西,他们都会被解析成现有的语法来执行,不使用他们没有丝毫的影响,他们的出现就是为了简化写法而已。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
SQL 关系型数据库 MySQL
SQL FULL OUTER JOIN 关键字
SQL FULL OUTER JOIN 关键字
48 2
|
10天前
|
SQL 分布式计算 Java
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
26 3
|
2月前
|
Java 网络架构 数据格式
Struts 2 携手 RESTful:颠覆传统,重塑Web服务新纪元的史诗级组合!
【8月更文挑战第31天】《Struts 2 与 RESTful 设计:构建现代 Web 服务》介绍如何结合 Struts 2 框架与 RESTful 设计理念,构建高效、可扩展的 Web 服务。Struts 2 的 REST 插件提供简洁的 API 和约定,使开发者能快速创建符合 REST 规范的服务接口。通过在 `struts.xml` 中配置 `<rest>` 命名空间并使用注解如 `@Action`、`@GET` 等,可轻松定义服务路径及 HTTP 方法。
48 0
|
2月前
|
SQL 存储 数据挖掘
"SQL JOIN大揭秘:解锁多表联合查询的终极奥义,从内到外,左至右,全连接让你数据世界畅通无阻!"
【8月更文挑战第31天】在数据库领域,数据常分散在多个表中,而SQL JOIN操作如同桥梁,连接这些孤岛,使数据自由流动,编织成复杂的信息网络。本文通过对比内连接、左连接、右连接和全连接的不同类型,并结合示例代码,展示SQL JOIN的强大功能。掌握JOIN技术不仅能高效查询数据,更是数据分析和数据库管理的关键技能。
70 0
|
3月前
|
JSON 数据格式 SQL
SQL开发问题之直接使用join方法在处理字符串类型属性时可能会遇到性能问题如何解决
SQL开发问题之直接使用join方法在处理字符串类型属性时可能会遇到性能问题如何解决
|
3月前
|
SQL
SQL FULL OUTER JOIN 关键字
【7月更文挑战第17天】SQL FULL OUTER JOIN 关键字。
37 6
|
3月前
|
SQL
SQL INNER JOIN 关键字
【7月更文挑战第17天】SQL INNER JOIN 关键字。
37 5
|
3月前
|
SQL 数据库
SQL LEFT JOIN 关键字
【7月更文挑战第17天】SQL LEFT JOIN 关键字。
30 4
|
3月前
|
SQL
SQL JOIN
【7月更文挑战第17天】SQL JOIN。
30 3
|
3月前
|
SQL 数据库
SQL RIGHT JOIN 关键字
【7月更文挑战第17天】SQL RIGHT JOIN 关键字。
36 2