SQL多表查询的几种连接方式

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: SQL多表查询时,主要使用以下几种连接方式

SQL多表查询时,主要使用以下几种连接方式:

  1. INNER JOIN (或 JOIN)
  • 返回两个表中都有的记录。
  • 只有在两个表中都存在匹配的记录时,才会返回结果。
  • 语法:SELECT * FROM table1 INNER JOIN table2 ON table1.column_name = table2.column_name;
  1. LEFT JOIN (或 LEFT OUTER JOIN)
  • 返回左表中的所有记录以及右表中匹配的记录。
  • 如果右表中没有匹配的记录,结果将返回NULL。
  • 语法:SELECT * FROM table1 LEFT JOIN table2 ON table1.column_name = table2.column_name;
  1. RIGHT JOIN (或 RIGHT OUTER JOIN)
  • 返回右表中的所有记录以及左表中匹配的记录。
  • 如果左表中没有匹配的记录,结果将返回NULL。
  • 语法:SELECT * FROM table1 RIGHT JOIN table2 ON table1.column_name = table2.column_name;
  1. FULL JOIN (或 FULL OUTER JOIN)
  • 返回左表和右表中的所有记录。
  • 如果某一侧没有匹配的记录,结果将返回NULL。
  • 语法:SELECT * FROM table1 FULL JOIN table2 ON table1.column_name = table2.column_name;
  1. CROSS JOIN
  • 返回左表和右表的笛卡尔积。
  • 如果左表有A条记录,右表有B条记录,那么结果将有A*B条记录。
  • 语法:SELECT * FROM table1 CROSS JOIN table2;
  1. SELF JOIN
  • 一个表与自己连接,通常用于比较同一表中的不同行。
  • 例如,找出具有相同姓名的两个不同的人。
  • 语法:SELECT * FROM table1 AS t1, table1 AS t2 WHERE t1.id != t2.id AND t1.name = t2.name;

在实际应用中,选择哪种连接方式取决于你的具体需求。了解每种连接方式的特性并正确应用它们是非常重要的。


www.heiblue.com】【www.msmhw.com】【www.ynyzy.cn】【www.xiaolong668.cn】【www.duniyun.com】【www.czchenyang.com】【www.huashengfz.com

www.qd-beihai.com】【www.march-wedding.com】【www.korimarin.com】【www.desiradeviaggi.com】【www.mechulkaptan.com】【www.pspintl.com

www.kuteicha.com】【www.zshn.net】【www.gandew.com

www.qiangbanglawyer.com】【www.strong-foot.com】【www.kei-work.com

www.ufmsinc.com

相关文章
|
4天前
|
SQL 关系型数据库 MySQL
六、SQL多表查询
六、SQL多表查询
31 0
|
4天前
|
SQL Java 数据库连接
JDBC的连接参数的设置导致rowid自动添加到sql
JDBC的连接参数的设置导致rowid自动添加到sql
13 1
|
4天前
|
SQL 安全 网络安全
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
76 0
|
4天前
|
SQL 消息中间件 分布式数据库
flink sql问题之连接HBase报错如何解决
Apache Flink是由Apache软件基金会开发的开源流处理框架,其核心是用Java和Scala编写的分布式流数据流引擎。本合集提供有关Apache Flink相关技术、使用技巧和最佳实践的资源。
201 0
|
4天前
|
SQL 网络协议 Java
【Java+SQL Server】前后端连接小白教程
【Java+SQL Server】前后端连接小白教程
27 0
|
4天前
|
SQL
SQL语句多表查询练习
SQL语句多表查询练习
13 0
|
4天前
|
SQL
在SQL中连接和复杂操作
在SQL中连接和复杂操作
25 0
|
4天前
|
SQL 数据库
面试题:Sql中的连接
面试题:Sql中的连接
30 5
|
4天前
|
SQL 关系型数据库 数据库连接
Python 连接 SQL 数据库 -pyodbc
以下是如何在 Python 中使用 pyodbc 连接到 SQL 数据库的基本步骤和详解
65 0
|
4天前
|
SQL 数据库
SQL FULL OUTER JOIN 关键字:左右表中所有记录的全连接解析
SQL RIGHT JOIN关键字返回右表(table2)中的所有记录以及左表(table1)中的匹配记录。如果没有匹配,则左侧的结果为0条记录。
71 0