SQL自学:什么是联结,如何编写使用联结的SELECT语句
在 SQL(Structured Query Language,结构化查询语言)的世界里,联结(JOIN)是一个强大且至关重要的概念。它允许我们从多个表中检索数据,从而实现更复杂的查询和数据分析。本文将深入探讨联结的概念、不同类型以及如何编写使用联结的 SELECT 语句。
一、联结的概念
联结是一种在 SQL 中用于合并两个或多个表中数据的操作。通过联结,我们可以基于共同的列值将不同表中的行组合在一起,从而获取更全面的信息。
想象一个数据库中有两个表:一个是 “Customers” 表,包含客户的 ID、姓名、地址等信息;另一个是 “Orders” 表,包含订单的 ID、客户 ID、订单日期、订单金额等信息。如果我们想要查看每个客户的订单信息,就需要使用联结将这两个表中的数据合并起来。
二、联结的类型
1、内联结(INNER JOIN)
内联结是最常用的联结类型之一。它只返回两个表中满足联结条件的行。
例如,假设有两个表 “TableA” 和 “TableB”,都有一个共同的列 “ID”。使用内联结的 SQL 语句如下:
SELECT *
FROM TableA
INNER JOIN TableB ON TableA.ID = TableB.ID;
这条语句将返回 “TableA” 和 “TableB” 中 “ID” 列值相等的行。
2、左联结(LEFT JOIN)
左联结返回左表中的所有行以及右表中与左表满足联结条件的行。如果右表中没有与左表匹配的行,则相应的列值为 NULL。
以下是使用左联结的示例:
SELECT *
FROM TableA
LEFT JOIN TableB ON TableA.ID = TableB.ID;
在这个例子中,“TableA” 是左表,它的所有行都会被返回。如果 “TableB” 中没有与 “TableA” 中某一行匹配的行,那么 “TableB” 的列值将为 NULL。
3、右联结(RIGHT JOIN)
右联结与左联结相反,它返回右表中的所有行以及左表中与右表满足联结条件的行。如果左表中没有与右表匹配的行,则相应的列值为 NULL。
示例如下:
SELECT *
FROM TableA
RIGHT JOIN TableB ON TableA.ID = TableB.ID;
4、全联结(FULL JOIN)
全联结返回两个表中的所有行。如果某一行在另一个表中没有匹配的行,则相应的列值为 NULL。
然而,并非所有的数据库都支持全联结。在支持全联结的数据库中,SQL 语句如下:
SELECT *
FROM TableA
FULL JOIN TableB ON TableA.ID = TableB.ID;
三、编写使用联结的 SELECT 语句
1、确定要联结的表
首先,你需要确定要联结的表以及它们之间的关系。这通常涉及找到共同的列,这些列将用于建立联结条件。
例如,在一个电子商务数据库中,可能有 “Customers” 表、“Orders” 表和 “Products” 表。“Customers” 表和 “Orders” 表可以通过 “CustomerID” 列联结,而 “Orders” 表和 “Products” 表可以通过 “ProductID” 列联结。
2、选择要检索的列
确定要从联结后的表中检索哪些列。你可以选择来自不同表的列,只要它们在 SELECT 语句中明确指定。
例如,要检索客户的姓名和他们的订单信息,可以使用以下 SQL 语句:
SELECT Customers.Name, Orders.OrderDate, Orders.OrderAmount
FROM Customers
INNER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;
3、指定联结条件
联结条件是用于确定哪些行应该被合并在一起的规则。通常,这是通过在 ON 子句中指定两个表中共同列的相等关系来实现的。
例如,继续上面的例子,联结条件是 “Customers.CustomerID = Orders.CustomerID”,这意味着只有当 “Customers” 表中的 “CustomerID” 列值与 “Orders” 表中的 “CustomerID” 列值相等时,这两行才会被合并。
4、使用别名
如果表名很长或者为了提高代码的可读性,可以为表指定别名。别名可以在 SELECT 语句中的任何地方使用,以代替表名。
例如:
SELECT c.Name, o.OrderDate, o.OrderAmount
FROM Customers AS c
INNER JOIN Orders AS o ON c.CustomerID = o.CustomerID;
在这个例子中,“Customers” 表被别名为 “c”,“Orders” 表被别名为 “o”。
5、处理多个联结
如果需要从多个表中检索数据,可以使用多个联结。在这种情况下,每个联结都需要有自己的联结条件。
例如,要检索客户的姓名、订单日期和订单中的产品名称,可以使用以下 SQL 语句:
SELECT c.Name, o.OrderDate, p.ProductName
FROM Customers AS c
INNER JOIN Orders AS o ON c.CustomerID = o.CustomerID
INNER JOIN OrderDetails AS od ON o.OrderID = od.OrderID
INNER JOIN Products AS p ON od.ProductID = p.ProductID;
在这个例子中,首先将 “Customers” 表和 “Orders” 表联结,然后将 “Orders” 表和 “OrderDetails” 表联结,最后将 “OrderDetails” 表和 “Products” 表联结。
四、联结的注意事项
1、性能考虑
联结操作可能会对数据库性能产生影响,尤其是当处理大量数据时。为了提高性能,可以考虑以下几点:
- 确保联结条件使用的列上有索引。
- 避免不必要的联结,只联结需要的表。
- 如果可能,使用内联结而不是全联结,因为全联结通常需要更多的处理时间。
2、数据完整性
在进行联结时,要确保数据的完整性。如果一个表中的数据与另一个表中的数据不匹配,可能会导致结果不准确。
例如,如果 “Customers” 表中的某个客户没有任何订单,那么在使用内联结时,这个客户将不会出现在结果中。如果需要包括所有客户,即使他们没有订单,可能需要使用左联结。
3、可读性
编写联结的 SQL 语句时,要注意代码的可读性。使用别名、注释和适当的缩进可以使代码更易于理解和维护。
例如:
-- 检索客户的姓名和他们的订单信息
SELECT c.Name, o.OrderDate, o.OrderAmount
FROM Customers AS c
INNER JOIN Orders AS o ON c.CustomerID = o.CustomerID;
练习题:
1.编写SQL语句,返回Customers表中的顾客名称(cust_name)和Orders表中的相关订单号(order_num),并按顾客名称再按订单号对结果进行排序。实际上是尝试两次,一次使用简单的等联结语法,一次使用INNER JOIN。
2.我们来让上一题变得更有用些。除了返回顾客名称和订单号,添加第三列OrderTotal,其中包含每个订单的总价。有两种方法可以执行此操作:使用OrderItems表的子查询来创建OrderTotal列,或者将OrderItems表与现有表联结并使用聚合函数。提示:请注意需要使用完全限定列名的地方。3.我们重新看一下第11课的挑战题2。编写SQL语句,检索订购产品BR01的日期,这一次使用联结和简单的等联结语法。
4.这次使用ANSI的INNER JOIN语法。在之前编写的代码中使用了两个嵌套的子查询。要重新创建它,需要两个INNER JOIN语句,每个语句的格式类似于本课讲到的INNERJOIN示例,而且不要忘记WHERE子句可以通过prod_id进行过滤。
5.再让事情变得更加有趣些,我们将混合使用联结、聚合函数和分组。编写SQL语句,使用联结从Customers表返回顾客名称(cust_name),并从OrderItems表返回所有订单的总价。提示:要联结这些表,还需要包括Orders表(因为Customers表与OrderItems表不直接相关,Customers表与Orders表相关,而Orders表与OrderItems表相关)。不要忘记GROUP BY和HAVING,并按顾客名称对结果进行排序。你可以使用简单的等联结或ANSI的INNER JOIN语法。
相关文章:
SQL自学:什么是联结,如何编写使用联结的SELECT语句
在 SQL(Structured Query Language,结构化查询语言)的世界里,联结(JOIN)是一个强大且至关重要的概念。它允许我们从多个表中检索数据,从而实现更复杂的查询和数据分析。本文将深入探讨联结的概念…...
【C++】函数重载+引用
大家好,我是苏貝,本篇博客带大家了解C的函数重载和引用,如果你觉得我写的还不错的话,可以给我一个赞👍吗,感谢❤️ 目录 一. 预处理、编译、汇编、链接二. 函数重载1 概念2 C支持函数重载的原理—名字修饰…...
华为S5735交换机console密码重置和恢复出厂设置
比较简单,简单说就是进入bootload清除密码,然后进入default mode下重置密码。 1.开机按CtrlB,进入启动加载菜单(BootLoad menu) 拨电源重启交换机,大约开机10多秒的时候会出现提示按CtrlB可以进入BootLoa…...
Spring Security无脑使用
步骤1:添加Spring Security依赖 在你的Spring Boot项目的pom.xml文件中,添加Spring Security的依赖: <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</art…...
学习 PostgreSQL + Spring Boot 3 +mybatisplus整合过程中的报错记录
今天计划学习 PostgreSQL,并顺便尝试使用 Spring Boot 3.x 框架,打算整合 Spring Boot 3、PostgreSQL 和 MyBatis-Plus。整合后一直出现以下报错: 去AI上面搜了讲的是sqlSessionFactory 或 sqlSessionTemplate 没有正确配置 初始分析&#…...
立仪光谱共焦传感器在玻璃测量技术上的突破
近年来,随着科技的不断发展,光谱共焦传感器逐渐成为了工业检测领域的重要工具。尤其是在玻璃这种透明材质的厚度测量中,光谱共焦传感器展现出了其独特的优势。立仪科技小编将围绕光谱共焦传感器在玻璃行业中的应用,从问题、分析到…...
Llama系列上新多模态!3.2版本开源超闭源,还和Arm联手搞了手机优化版,Meta首款多模态Llama 3.2开源!1B羊驼宝宝,跑在手机上了
Llama系列上新多模态!3.2版本开源超闭源,还和Arm联手搞了手机优化版,Meta首款多模态Llama 3.2开源!1B羊驼宝宝,跑在手机上了! 在多模态领域,开源模型也超闭源了! 就在刚刚结束的Met…...
系统缺失mfc140.dll的修复方法,有效修复错误mfc140.dll详细步骤
mfc140.dll丢失原因分析 1 系统文件损坏或病毒感染 系统文件损坏或被病毒感染是导致mfc140.dll丢失的常见原因之一。根据用户反馈和安全研究报告,大约有30%的mfc140.dll丢失案例与系统文件损坏或病毒感染有关。病毒、木马或其他恶意软件可能会破坏或删除系统中的m…...
移动app的UI和接口自动化测试怎么进行?
标题:从0到1:移动App的UI和接口自动化测试 导语:移动App的快速发展使得UI和接口自动化测试成为了确保应用质量的重要环节。本文将从零开始介绍移动App的UI和接口自动化测试的基本概念以及如何进行测试。 第一部分:了解移动App自动…...
Unity实现自定义图集(二)
以下内容是根据Unity 2020.1.0f1版本进行编写的 实现一个自定义图集,该怎么入手呢。首先简单思考一下unity是怎么实现图集的。 因为unity的ui部分是开源的,所以我们可以看到UGUI的源代码,另外,Unity的内置Shader也是开源的,可以直接在官网下载(在下载的网页选择Built…...
智能码二维码zhinengma.cn的动态数据更新是如何实现的?
智能码二维码的动态数据更新功能是通过其背后的技术原理实现的,主要依赖于服务器和二维码的链接结构。以下是具体介绍: 动态数据更新的实现原理 链接嵌入:动态二维码中嵌入了一个链接,该链接指向服务器上的数据源。数据请求与更…...
uniapp view怎么按长度排列一行最多四个元素,并且换行后,每一行之间都有间隔
推荐学习文档 golang应用级os框架,欢迎stargolang应用级os框架使用案例,欢迎star案例:基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总想学习更多golang知识,这里有免费的golang学习笔…...
Android列表组件api
目录 1.ListView控件 1)android:divider 2)android:dividerHeight 3)android:entries 4)android:footerDividersEnabled 5)android:headerDividersEnabled 6)android:listSelector 7)android:sc…...
ToB项目身份认证AD集成(完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法介绍
在前面的两篇文章中,我详细的介绍了使用ldap与window AD服务集成,实现ToB项目中的身份认证集成方案,包括技术方案介绍、环境配置: ToB项目身份认证AD集成(一):基于目录的用户管理、LDAP和Active…...
SpringBoot+SeetaFace6搭建人脸识别平台
前言 最近多个项目需要接入人脸识别功能,之前的方案是使用百度云api集成,但是后续部分项目是内网部署及使用,考虑到接入复杂程度及收费等多种因素,决定参考开源方案自己搭建,保证服务的稳定性与可靠性 项目地址&…...
MySQL-06.DDL-表结构操作-创建
一.DDL(表操作) create database db01;use db01;create table tb_user(id int comment ID,唯一标识,username varchar(20) comment 用户名,name varchar(10) comment 姓名,age int comment 年龄,gender char(1) comment 性别 ) comment 用户表; 此时并没有限制ID为…...
在Visual Studio中使用CMakeLists.txt集成EasyX库的详细指南
EasyX库是一款专为Windows平台设计的轻量级C图形库,适合初学者和教育领域使用。结合Visual Studio和CMake工具链,用户可以轻松创建C项目,并集成EasyX库,实现丰富的图形编程效果。本文将详细介绍如何在Visual Studio中通过CMakeLis…...
CRC码计算原理
CRC8这里先以CRC8来说明CRC的计算过程1、CRC8在线计算器通过CRC在线计算器可以看见CRC8的特征多项式:x8+x2+x+1,初始值为0000’0000。CRC计算的核心是:反转+异或+移位(此处的CRC8没有涉及反转,见后面CRC16)。2、CRC8计算过程(1)、取值从高到低依次取需校验数据的位,这里…...
对高危漏洞“Docker Engine API is accessible without authentication”的修复
一.背景 之前文章maven项目容器化运行之1-基于1Panel软件将docker镜像构建能力分享给局域网_1panel 构建镜像-CSDN博客将1Panel软件的Doocker端口给到了局域网,安全组兄弟扫描认为是高危漏洞,可能导致攻击者获取对Docker主机的完全控制权。 二.修复的建…...
两种方式创建Vue项目
文章目录 引言利用Vue命令创建Vue项目准备工作安装Vue CLI创建Vue项目方法一:使用vue init命令方法二:使用vue create命令启动Vue项目 利用Vite工具创建Vue项目概述利用Vite创建项目启动项目 结语 引言 大家好,今天我将向大家展示如何使用不…...
C++初阶-list的底层
目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...
Python爬虫实战:研究feedparser库相关技术
1. 引言 1.1 研究背景与意义 在当今信息爆炸的时代,互联网上存在着海量的信息资源。RSS(Really Simple Syndication)作为一种标准化的信息聚合技术,被广泛用于网站内容的发布和订阅。通过 RSS,用户可以方便地获取网站更新的内容,而无需频繁访问各个网站。 然而,互联网…...
LeetCode - 394. 字符串解码
题目 394. 字符串解码 - 力扣(LeetCode) 思路 使用两个栈:一个存储重复次数,一个存储字符串 遍历输入字符串: 数字处理:遇到数字时,累积计算重复次数左括号处理:保存当前状态&a…...
蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练
前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...
linux 下常用变更-8
1、删除普通用户 查询用户初始UID和GIDls -l /home/ ###家目录中查看UID cat /etc/group ###此文件查看GID删除用户1.编辑文件 /etc/passwd 找到对应的行,YW343:x:0:0::/home/YW343:/bin/bash 2.将标红的位置修改为用户对应初始UID和GID: YW3…...
ubuntu22.04有线网络无法连接,图标也没了
今天突然无法有线网络无法连接任何设备,并且图标都没了 错误案例 往上一顿搜索,试了很多博客都不行,比如 Ubuntu22.04右上角网络图标消失 最后解决的办法 下载网卡驱动,重新安装 操作步骤 查看自己网卡的型号 lspci | gre…...
Python网页自动化Selenium中文文档
1. 安装 1.1. 安装 Selenium Python bindings 提供了一个简单的API,让你使用Selenium WebDriver来编写功能/校验测试。 通过Selenium Python的API,你可以非常直观的使用Selenium WebDriver的所有功能。 Selenium Python bindings 使用非常简洁方便的A…...
Android写一个捕获全局异常的工具类
项目开发和实际运行过程中难免会遇到异常发生,系统提供了一个可以捕获全局异常的工具Uncaughtexceptionhandler,它是Thread的子类(就是package java.lang;里线程的Thread)。本文将利用它将设备信息、报错信息以及错误的发生时间都…...
如何通过git命令查看项目连接的仓库地址?
要通过 Git 命令查看项目连接的仓库地址,您可以使用以下几种方法: 1. 查看所有远程仓库地址 使用 git remote -v 命令,它会显示项目中配置的所有远程仓库及其对应的 URL: git remote -v输出示例: origin https://…...
2025-05-08-deepseek本地化部署
title: 2025-05-08-deepseek 本地化部署 tags: 深度学习 程序开发 2025-05-08-deepseek 本地化部署 参考博客 本地部署 DeepSeek:小白也能轻松搞定! 如何给本地部署的 DeepSeek 投喂数据,让他更懂你 [实验目的]:理解系统架构与原…...
