SQL两表/多表关联查询--JOIN语句

2024-01-18 06:20

本文主要是介绍SQL两表/多表关联查询--JOIN语句,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、基础概念

SQL中的关联是通过JOIN关键字实现的,JOIN关键字有几种类型,包括INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL OUTER JOIN等。

二、INNER JOIN详解

INNER JOIN是最常用的关联方式之一,它返回 两个表中共同存在的数据行

其语法格式如下:

SELECT column1, column2, ...
FROM table1
INNER JOIN table2
ON table1.column_name = table2.column_name;

下面是一个实际的例子:

SELECT customer.name, orders.order_date
FROM customer
INNER JOIN orders
ON customer.id = orders.customer_id;

以上代码可以得到一个结果集,其中包含了客户的姓名和他们所下的订单的日期。

三、LEFT JOIN详解

LEFT JOIN也是一种常用的关联方式,它 返回 左表中的所有数据行 右表中与其匹配的数据行

其语法格式如下:

SELECT column1, column2, ...
FROM table1
LEFT JOIN table2
ON table1.column_name = table2.column_name;

下面是一个实际的例子:

SELECT customer.name, orders.order_date
FROM customer
LEFT JOIN orders
ON customer.id = orders.customer_id;

以上代码可以得到一个结果集,其中包含了客户的姓名和他们所下的订单的日期,如果某个客户没有下订单,它的订单日期将会被赋为NULL。

四、RIGHT JOIN详解

RIGHT JOIN与LEFT JOIN类似,只不过返回的是 右表中的所有数据行 左表中与其匹配的数据行

其语法格式如下:

SELECT column1, column2, ...
FROM table1
RIGHT JOIN table2
ON table1.column_name = table2.column_name;

下面是一个实际的例子:

SELECT customer.name, orders.order_date
FROM customer
RIGHT JOIN orders
ON customer.id = orders.customer_id;

以上代码可以得到一个结果集,其中包含了订单的日期和下订单的客户姓名,如果某个订单没有对应的客户,它的客户姓名将会被赋为NULL。

五、FULL OUTER JOIN详解

FULL OUTER JOIN则返回 左表 和 右表中的所有数据行无论是否匹配

其语法格式如下:

SELECT column1, column2, ...
FROM table1
FULL OUTER JOIN table2
ON table1.column_name = table2.column_name;

下面是一个实际的例子:

SELECT customer.name, orders.order_date
FROM customer
FULL OUTER JOIN orders
ON customer.id = orders.customer_id;

以上代码可以得到一个结果集,其中包含了所有客户和他们所下的订单的日期,如果某个客户没有下订单,它的订单日期将会被赋为NULL,同样地,如果某个订单没有对应的客户,它的客户姓名将会被赋为NULL。

六、注意事项

关联查询可能会导致性能问题,需要合理利用索引优化手段。

参考:SQL两表关联查询详解_笔记大全_设计学院

这篇关于SQL两表/多表关联查询--JOIN语句的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/618269

相关文章

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

MySQL数据库实现批量表分区完整示例

《MySQL数据库实现批量表分区完整示例》通俗地讲表分区是将一大表,根据条件分割成若干个小表,:本文主要介绍MySQL数据库实现批量表分区的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录一、表分区条件二、常规表和分区表的区别三、表分区的创建四、将既有表转换分区表脚本五、批量转换表为分区

宝塔安装的MySQL无法连接的情况及解决方案

《宝塔安装的MySQL无法连接的情况及解决方案》宝塔面板是一款流行的服务器管理工具,其中集成的MySQL数据库有时会出现连接问题,本文详细介绍两种最常见的MySQL连接错误:“1130-Hostisn... 目录一、错误 1130:Host ‘xxx.xxx.xxx.xxx’ is not allowed

sql语句字段截取方法

《sql语句字段截取方法》在MySQL中,使用SUBSTRING函数可以实现字段截取,下面给大家分享sql语句字段截取方法,感兴趣的朋友一起看看吧... 目录sql语句字段截取sql 截取表中指定字段sql语句字段截取1、在mysql中,使用SUBSTRING函数可以实现字段截取。例如,要截取一个字符串字

SQL Server身份验证模式步骤和示例代码

《SQLServer身份验证模式步骤和示例代码》SQLServer是一个广泛使用的关系数据库管理系统,通常使用两种身份验证模式:Windows身份验证和SQLServer身份验证,本文将详细介绍身份... 目录身份验证方式的概念更改身份验证方式的步骤方法一:使用SQL Server Management S

MySQL 字符串截取函数及用法详解

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST... 目录mysql 字符串截取函数详解RIGHT(str, length):从右侧截取指定长度的字符SUBST

MySQL中的事务隔离级别详解

《MySQL中的事务隔离级别详解》在MySQL中,事务(Transaction)是一个执行单元,它要么完全执行,要么完全回滚,以保证数据的完整性和一致性,下面给大家介绍MySQL中的事务隔离级别详解,... 目录一、事务并发问题二、mysql 事务隔离级别1. READ UNCOMMITTED(读未提交)2

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有