T-SQL 语言基础:表运算符与联接

news2025/3/12 13:22:25

目录

  1. 介绍
  2. 表运算符概述
  3. 交叉联接
  4. 内联接
  5. 外联接
  6. 联接实例
  7. 总结
  8. 引用
1. 介绍

在这篇博客中,主要涉及 T-SQL 中的表运算符与联接。联接操作是 SQL 查询中最常用的操作之一,它允许我们在多个表之间进行数据关联。通过了解不同类型的联接及其应用场景,可以更有效地处理和分析数据库中的数据。

2. 表运算符概述

表运算符是 SQL 中用于将两个或多个表的结果集组合在一起的操作符。常见的表运算符包括交叉联接、内联接和外联接。每种联接类型都有其特定的用途和行为,了解它们的差异对于编写高效的 SQL 查询至关重要。

3. 交叉联接

交叉联接返回两个表的笛卡尔积,即每个表中的每一行与另一个表中的每一行进行组合。这种联接通常用于生成所有可能的行组合,但在大多数实际应用中使用较少,可能会产生非常大的结果集。

-- 示例交叉联接
SELECT A.*, B.*
FROM TableA AS A
CROSS JOIN TableB AS B;

这个查询返回了 TableATableB 的所有可能组合。

4. 内联接

内联接返回两个表中匹配的行。它是最常用的联接类型,用于只返回满足联接条件的行。

-- 示例内联接
SELECT A.*, B.*
FROM TableA AS A
INNER JOIN TableB AS B ON A.key = B.key;

这个查询返回了 TableATableB 中键相等的行。

5. 外联接

外联接包括左外联接、右外联接和全外联接。它们不仅返回匹配的行,还返回未匹配的行,并用 NULL 填充未匹配部分的数据。

-- 创建示例表 TableA
CREATE TABLE TableA (
    key INT,
    valueA VARCHAR(50)
);

-- 创建示例表 TableB
CREATE TABLE TableB (
    key INT,
    valueB VARCHAR(50)
);

-- 插入示例数据到 TableA
INSERT INTO TableA (key, valueA) VALUES
(1, 'A1'),
(2, 'A2'),
(3, 'A3'),
(4, 'A4');

-- 插入示例数据到 TableB
INSERT INTO TableB (key, valueB) VALUES
(3, 'B3'),
(4, 'B4'),
(5, 'B5'),
(6, 'B6');

左外联接示例

SELECT A.*, B.*
FROM TableA AS A
LEFT JOIN TableB AS B ON A.key = B.key;
Image

– 右外联接示例

SELECT A.*, B.*
FROM TableA AS A
RIGHT JOIN TableB AS B ON A.key = B.key;

输出结果:

Image
-- 全外联接示例
SELECT A.*, B.*
FROM TableA AS A
FULL JOIN TableB AS B ON A.key = B.key;

输出结果:

Image

这些查询分别返回 TableATableB 中左表、右表和全部匹配及未匹配的行。

6. 联接实例

在实际应用中,有时需要使用复杂的联接操作来满足特定需求。

  1. 查询所有客户及其订单信息
USE TSQLFundamentals2008;

SELECT C.*, O.*
FROM sales.Customers AS C
LEFT JOIN sales.Orders AS O ON C.custid = O.custid;

输出结果:

Image
  1. 查询没有下过订单的客户
SELECT C.*
FROM Customers AS C
LEFT JOIN Orders AS O ON C.CustomerID = O.CustomerID
WHERE O.OrderID IS NULL;

输出结果:

Image

第一个查询返回了所有客户及其订单信息。第二个查询返回没有下过订单的客户。

7. 总结

这篇博客,我们学习了 T-SQL 中的表运算符和联接操作,交叉联接、内联接和外联接的用法以及联接实例。理解这些联接操作的使用场景和效果,可以在数据查询和分析中更加高效和准确。

8. 引用
  • Microsoft SQL Server 文档
  • W3Schools SQL 教程

引用

  • Microsoft SQL Server 文档

数据库脚本下载

TSQLFundamentals2008

**喜欢的话,请收藏 | 关注(✪ω✪)**
……**万一有趣的事还在后头呢,Fight!!(o^-^)~''☆ミ☆ミ**……

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

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

相关文章

jumpserver 网络安全 网络安全 authenticity

1.1 计算机安全的概念 1.1.1 计算机安全最核心的三个关键目标(CIA): 保密性(Confidentiality)--①数据保密性(确保隐私或秘密不向非授权者泄密或使用); ②隐私性(确保个人能够控制或确定其自身相关的信息&#xff09…

Spring Cloud之远程调用OpenFeign参数传递

目录 OpenFeign参数传递 传递单个参数 传递多个参数 传递对象 传递JSON OpenFeign参数传递 传递单个参数 服务提供方product-service RequestMapping("/product") RestController public class ProductController {Autowiredprivate ProductService productSe…

网络安全之文件上传漏洞

一,文件上传漏洞的原因: 文件上传漏洞的存在主要是因为开发者未对用户上传的文件进行充分的安全验证,导致攻击者可以上传恶意文件(如 WebShell、恶意脚本等)到服务器,进而控制服务器或实施进一步攻击。 常…

Fast DDS Security--仿问控制

Fast DDS中提供了两种级别的仿问控制: 1 Domain Governance: 定义域级别的安全策略(全局规则). 2 DomainParticipant Permissions : 定义参与者的具体权限(个体规则) 先说一下Domain Governance&#xf…

为什么大模型网站使用 SSE 而不是 WebSocket?

在大模型网站(如 ChatGPT、Claude、Gemini 等)中,前端通常使用 EventSource(Server-Sent Events, SSE) 来与后端对接,而不是 WebSocket。这是因为 SSE 更适合类似流式文本生成的场景。下面我们详细对比 SSE…

基于Matlab设计GUI图像处理交互界面

Image-Processing-GUI 项目说明 本博文提供了完整的代码和使用教程,适合新入门的朋友参考,完整代码资源文件请转至文末的下载链接。 本项目是《Matlab实践》中图像处理软件题目,本项目实现的具体内容如下 基于Matlab设计GUI交互界面图像的…

osg安装编译第三方,完整详细过程。 libtiff/tif config.vc.hdoes not exist

第三方安装包下载地址 GitHub - bjornblissing/osg-3rdparty-cmake: CMake scripts for building OpenSceneGraph third party libraries. 在计算机中的布局 D:\CPlus\osg\src\osg-3rdparty\osg-3rdparty-cmake三层布局,src 放置源码 执行里面的批处理文件&#…

RSA算法:开启现代密码学的数学之钥

一、RSA算法简介 RSA(Rivest-Shamir-Adleman)是当今应用最广泛的非对称加密算法,由三位科学家Ron Rivest、Adi Shamir和Leonard Adleman于1977年提出。它的核心思想是利用数论中的难题,构建一对数学上关联的密钥——公钥用于加密…

Android Compose Surface 完全指南:从入门到花式操作

今天咱们来聊聊 Compose 世界里那个既基础又强大的组件——Surface。这个看似简单的矩形区域,实际藏着不少宝藏玩法,准备好你的 IDE,咱们发车! 一、Surface 是什么? 简单说,Surface 就是个自带背景和样式…

Deepin通过二进制方式升级部署高版本 Docker

一、背景: 在Deepin系统中通过二进制方式升级部署高版本 Docker,下面将详细介绍二进制方式升级部署高版本 Docker 的具体步骤。 二、操作步骤 1.根据需求下载二进制文件,下载地址如下: https://mirrors.tuna.tsinghua.e…

python中time模块的常用方法及应用

Python 的 time 模块是自带的标准模块,不需要额外安装,可以直接通过import time的方式导入并使用其中的函数和类。该模块提供了与时间相关的各种功能,以下是一些常用方法及其应用场景和示例: ### 1. time.time() - **功能**&…

【RTSP】客户端(一):RTSP协议实现

概述 RTSP主要功能总结 RTSP本质是一个应用层协议,主要用于控制实时数据的传递,例如音视频流。RTSP的传输方式与HTTP类似,与HTTP不同在于RTSP主要用于控制传输媒体服务器上的流媒体会话。所以其是一个 客户端-服务器模型,客户端需…

SpringBoot(一)--搭建架构5种方法

目录 一、⭐Idea从spring官网下载打开 2021版本idea 1.打开创建项目 2.修改pom.xml文件里的版本号 2017版本idea 二、从spring官网下载再用idea打开 三、Idea从阿里云的官网下载打开 ​编辑 四、Maven项目改造成springboot项目 五、从阿里云官网下载再用idea打开 Spri…

【工控】线扫相机小结 第五篇

背景介绍 线扫相机通过光栅尺的脉冲触发, 我在调试线扫过程中,发现图像被拉伸,预设调节分配器。图像正常后,我提高的相机的扫描速度(Y轴动的更快了)。 动的更快的发现,图像变短了(以…

【STM32F103C8T6】DMA数据转运ADC多通道

前言 本节为代码部分,知识点在这【江协科技STM32】DMA直接存储器存储-学习笔记-CSDN博客 查看数据地址: uint8_t aa 0x88;int main(void) {OLED_Init();OLED_ShowHexNum(1,1,aa,4); //显示十六进制数 OLED_ShowHexNum(2,1,(uint32_t)&aa,8);wh…

计算机网络--访问一个网页的全过程

文章目录 访问一个网页的全过程应用层在浏览器输入URL网址http://www.aspxfans.com:8080/news/index.aspboardID5&ID24618&page1#r_70732423通过DNS获取IP地址生成HTTP请求报文应用层最后 传输层传输层处理应用层报文建立TCP连接传输层最后 网络层网络层对TCP报文进行处…

JVM G1垃圾回收器详细解析

G1内存布局 Garbage First(简称G1)收集器摒弃了传统垃圾收集器的严格的内存划分,而是采用了基于Region的内存布局形式和局部回收的设计思路。 G1垃圾收集器把Java堆划分为2048个大小相等的独立的Region,每个Region大小取值范围为1-32MB,且必…

OpenGL中绘制图形元素的实现(使用visual studio(C++)绘制一个矩形)

目标&#xff1a;使用OpenGL提供的函数绘制矩形、线段、三角形等基本图形元素 所需效果 实验步骤 1、配置OpenGL&#xff08;详情参见OpenGL的配置&#xff09; 2、头文件引入 #include <gl/glut.h> 3、编写方法体 1>矩形实现 //绘制矩形 void DisplayRectangl…

数据库---sqlite3

数据库&#xff1a; 数据库文件与普通文件区别: 1.普通文件对数据管理(增删改查)效率低 2.数据库对数据管理效率高,使用方便 常用数据库: 1.关系型数据库: 将复杂的数据结构简化为二维表格形式 大型:Oracle、DB2 中型:MySql、SQLServer …

【阿里云】控制台使用指南:从创建ECS到系统诊断测评

前言 随着云计算技术的快速发展&#xff0c;越来越多的企业和开发者开始使用云服务来部署和管理应用程序。在众多云服务提供商中&#xff0c;阿里云&#xff08;Alibaba Cloud&#xff09;凭借其强大的基础设施和丰富的服务&#xff0c;成为了众多用户的首选。本文旨在介绍如何…