解锁数据关联之道:SQL 表连接详解

文章目录

  • 概述
  • 表关系
  • 横向连接
    • 内连接 inner join
    • 左连接 left join
    • 右连接 right join
    • 全连接 full join
    • 交叉连接 cross join
  • 纵向合并
    • UNION ALL
    • UNION

概述

在数据处理、数据分析中常会用到表连接。表连接的作用是将多个表中的数据关联起来,以便在查询过程中获取更全面和准确的信息。。通过表连接,可以更灵活地处理和分析数据库中的数据,提供更全面和准确的查询结果。使用表连接有以下功能:

  • 获取相关数据: 当数据分散在多个表中时,通过表连接可以将这些表中的相关数据关联起来。例如,在一个电子商务系统中,订单信息可能存储在一个表中,而客户信息可能存储在另一个表中。通过表连接,可以将订单表和客户表中的数据关联起来,从而获取包括订单和客户信息的完整记录。
  • 实现数据聚合: 表连接可以用于将多个表中的数据进行聚合计算。通过连接与聚合函数结合使用,可以进行复杂的统计和汇总操作。例如,在销售数据分析中,可以将订单表和产品表连接,并使用聚合函数计算每个产品的销售总额、平均价格等统计指标。
  • 支持复杂的查询条件: 使用表连接可以在查询条件中同时使用多个表的列进行筛选和过滤。这样可以根据多个表的关系和条件进行更精确的查询。例如,可以通过连接客户表和订单表,并根据客户的地理位置和订单的日期范围进行筛选,以获取特定地区在特定时间内的订单数据。
  • 提高查询性能: 通过适当地使用表连接,可以减少数据冗余和重复存储,从而提高查询性能。

表关系

表关系指的是数据库中不同表之间的关联关系。这种关系通常通过表中的共同列(键)建立起来,以便在查询数据时能够在不同表之间建立连接并获取相关信息。表关系通常可以分为以下几种类型:

  • 一对一关系: 两个表中的每个记录在关联字段上都有唯一的对应。这种关系通常用于将不同方面的信息分开存储,以保持数据的规范性和整洁性。
    在这里插入图片描述

  • 一对多关系: 一个表中的记录在关联字段上可以对应多个另一个表中的记录。这种关系常见于主从表的关系,例如一个客户可能有多个订单。

  • 多对一关系: 多个表中的记录在关联字段上对应同一个表中的记录。这种关系通常指向关联字段具有相同值的情况。
    在这里插入图片描述

  • 多对多关系: 两个表之间的记录可以相互关联,并且每个记录在关联字段上可以对应多个另一个表中的记录。为了建立这种关系,通常需要通过第三张关系表来实现。
    在这里插入图片描述

通过合理设计表关系,可以避免数据冗余、确保数据一致性,并且使得数据库的结构更加清晰和易于维护。在进行数据查询时,表关系能够帮助我们获取跨表的相关信息,进行复杂的数据分析和处理操作。

横向连接

数据:
在这里插入图片描述

内连接 inner join

返回左表与右边关键值一致的行(两表的交集)。

select * from t1 inner join  t2 on t1.key1 = t2.key2;

在这里插入图片描述

左连接 left join

返回左表中的所有行,以及右表中与左表匹配的行。

select * from t1 left join  t2 on t1.key1 = t2.key2;

在这里插入图片描述

右连接 right join

返回右表中的所有行,以及左表中与右表匹配的行。

select * from t1 right join  t2 on t1.key1 = t2.key2;

在这里插入图片描述

全连接 full join

返回左右两个表中所有的行,并将它们匹配起来,如果其中一个表中没有匹配的行,则用 NULL 值填充。(两表的并集)

select * from t1 full join  t2 on t1.key1 = t2.key2;

在这里插入图片描述

交叉连接 cross join

交叉连接会返回两个表的笛卡尔积,即左表中的每一行都会与右表中的每一行匹配。

SELECT *
FROM table1
CROSS JOIN table2;

示例:
在这里插入图片描述

纵向合并

纵向合并是为了追加/增加记录。通常情况下,纵向合并需要满足以下条件:

  • 两张表必须拥有相同数量的字段
  • 两张表字段的顺序必须相同
  • 两张表对应字段的数据类型必须一致
  • 字段名可以不相同,选取主数据集的字段名
    在这里插入图片描述

UNION ALL

UNION ALL操作符用于合并结果集时不会去重,即结果集中可能包含重复的行。

SELECT column1, column2
FROM table1
UNION ALL
SELECT column1, column2
FROM table2;

UNION

UNION操作符用于合并结果集时会自动去重,即去除重复的行。

SELECT column1, column2
FROM table1
UNION 
SELECT column1, column2
FROM table2;

在SQL中,UNION和UNION ALL都是用于合并两个或多个SELECT语句的结果集的操作符。它们的主要区别在于对重复行的处理方式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/841063.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

嵌入式0基础开始学习 ⅠC语言(8)结构体

0.问题引入 C语言是允许程序员定义自己的组合类型 构造类型 》 数组 结构体 枚举 共用体/联合体 …

Vxetable 递归多级表头

在对vxetable 进行二次封装的时候&#xff0c;多级表头也是需要考虑进去的&#xff0c;所以需要封装一个递归列组件进行多级表头的一个渲染。 // my-table.vue <vxe-tableref"xTable":key"currentKey":data"pageData?.list || []"show-head…

Flutter 中的 MergeableMaterial 小部件:全面指南

Flutter 中的 MergeableMaterial 小部件&#xff1a;全面指南 Flutter 提供了丰富的 Material Design 组件&#xff0c;用于构建具有丰富交互和视觉效果的用户界面。MergeableMaterial 是 Flutter 中一个特殊的组件&#xff0c;它允许多个 Material widget&#xff08;如按钮、…

2024-5-25

今日安排&#xff1a; 前面的状态不太好&#xff0c;后面一定要好好调整 重新开始审计 nf_tables 源码&#xff0c;并在审计的过程中复现历史漏洞【 && iptables 相关学习】♥♥♥♥♥复现 CTF 相关题目♥♥♥♥学习 winpwn♥♥♥♥mount 的使用&#xff0c;学习 nam…

js 根据日期获取星期几

js 根据日期获取星期几 方法一&#xff1a;使用Date对象中的getDay()方法 function getWeekday(dateStr) {const weekDays [星期日, 星期一, 星期二, 星期三, 星期四, 星期五, 星期六];const date new Date(dateStr);const weekday date.getDay();return weekDays[weekday…

MySQL造数据占用临时表空间

在数据库性能测试和开发过程中&#xff0c;常常需要生成大量的测试数据以模拟真实环境。在MySQL中&#xff0c;造数据的过程可能会占用大量的临时表空间&#xff0c;这可能会影响数据库的性能和稳定性。本文将深入探讨MySQL造数据时临时表空间的使用情况&#xff0c;并通过多个…

GolangFoundation

GolangFoundation 一. Hello World1.1 SDK1.2 环境1.3 hello world1.4 语法规则二. 变量2.1 变量声明与定义一. Hello World 1.1 SDK https://golang.google.cn/dl/下载最新版1.2 环境 GoGOROOT D:\Dev\

家政项目day2 需求分析(模拟入职后熟悉业务流程)

目录 1 项目主体介绍1.1 项目背景1.2 运营模式1.3 项目业务流程 2 运营端需求2.1 服务类型管理2.2 服务项目&#xff08;服务&#xff09;管理2.3 区域管理2.4 区域服务管理2.5 相关数据库表的管理2.6 设计工程结构2.7 测试接口&#xff08;接口断点查看业务代码&#xff09; 1…

【机器学习与大模型】开源大模型和闭源大模型:技术发展与社会责任的平衡点

目录 &#x1f4a1;引言✈️✈️一&#xff0c;开源大模型的优势与劣势✈️✈️1.1 优势&#xff1a;✈️✈️1.2 挑战和劣势&#xff1a; &#x1f680;&#x1f680;2. 闭源大模型的优势与劣势&#x1f680;&#x1f680;2.1 优势&#xff1a;&#x1f680;&#x1f680;2.2 …

所有笔记总结目录

算法篇&#xff08;C&#xff09; 算法链接基础知识基础算法总结-CSDN博客数据结构数据结构总结-CSDN博客搜索与图论搜索与图论总结-CSDN博客数学知识数学知识总结-CSDN博客动态规划动态规划总结&#xff08;闫氏Dp分析法&#xff09;-CSDN博客贪心贪心算法总结-CSDN博客 基础…

动态计算rem

前言: 最近导师布置了一些作业&#xff0c;其中有一个就是动态计算rem&#xff0c;我想到了两个版本&#xff0c;一种是不添加防抖&#xff0c;当视口发生变化时&#xff0c;就立即进行计算rem&#xff0c;还是一种就是使用防抖&#xff0c;当视口连续100毫秒没有发生变化时计…

【pyspark速成专家】7_SparkSQL编程1

目录 一&#xff0c;RDD&#xff0c;DataFrame和DataSet对比 二&#xff0c;创建DataFrame 本节将介绍SparkSQL编程基本概念和基本用法。 不同于RDD编程的命令式编程范式&#xff0c;SparkSQL编程是一种声明式编程范式&#xff0c;我们可以通过SQL语句或者调用DataFrame的相…

YoloV8改进策略:蒸馏改进|MimicLoss|使用蒸馏模型实现YoloV8无损涨点|特征蒸馏

摘要 在本文中&#xff0c;我们成功应用蒸馏策略以实现YoloV8小模型的无损性能提升。我们采用了MimicLoss作为蒸馏方法的核心&#xff0c;通过对比在线和离线两种蒸馏方式&#xff0c;我们发现离线蒸馏在效果上更为出色。因此&#xff0c;为了方便广大读者和研究者应用&#x…

amis 联动效果触发的几种方式

联动效果实现主要俩种方式: 1.表达式实现联动,基于组件内或数据链的变量变化的联动 比如&#xff1a; "source": "/amis/api/mock2/options/level2?name${name} " (必须是这种字符串拼接形式,在data数据映射中表达式不会触发联动) 所有初始化接口链…

【c++基础】分书问题

说明 已知有n本书&#xff08;从1&#xff5e;n编号&#xff09;和n个人&#xff08;从1&#xff5e;n编号&#xff09;&#xff0c;每个人都有一个自己喜爱的书的列表&#xff0c;现在请你编写一个程序&#xff0c;设计一种分书方案&#xff0c;使得每个人都能获得一本书&…

AI专业面经

AI专业面经&#xff08;部分&#xff09; 一、数学部分&#xff1a; 1.1 代数&#xff08;Algebra&#xff09;和分析&#xff08;Analysis&#xff09;&#xff1a;复习基本的代数和微积分概念&#xff0c;如线性代数、微分、积分等。 1.1.1 Algebra 1.1.1.1 基础知识 Rea…

Java进阶学习笔记10——子类构造器

子类构造器的特点&#xff1a; 子类的全部构造器&#xff0c;都会先调用父类的构造器&#xff0c;再执行自己。 子类会继承父类的数据&#xff0c;可能还会使用父类的数据。所以&#xff0c;子类初始化之前&#xff0c;一定先要完成父类数据的初始化&#xff0c;原因在于&…

线程生命周期

创建线程的两种方法 1.继承Thread类 2.实现Runnable接口 线程从创建到消亡分为新建、就绪、运行、阻塞、死亡5种状态。 新建状态 创建一个线程就处于新建状态。此时线程对象已经被分配了内存空间&#xff0c;并且私有数据也被初始化&#xff0c;但是该线程还不能运行。 就…

EventSource

什么是EventSource EventSource 是一个用于服务器推送事件&#xff08;Server-Sent Events, SSE&#xff09;的接口&#xff0c;它允许服务器推送实时更新到浏览器。与 WebSocket 不同&#xff0c;SSE 是单向的&#xff08;服务器到客户端&#xff09;&#xff0c;适用于更新频…

03-02-Vue组件之间的传值

前言 我们接着上一篇文章 03-01-Vue组件的定义和注册 来讲。 下一篇文章 04-Vue&#xff1a;ref获取页面节点–很简单 父组件向子组件传值 我们可以这样理解&#xff1a;Vue实例就是一个父组件&#xff0c;而我们自定义的组件&#xff08;包括全局组件、私有组件&#xff09;…