SQL Server 数据库,多表查询

4.2使用T-SQL实现多表查询

前面讲述过的所有查询都是基于单个数据库表的查询,如果一个查询需要对多个表进行操作, 就称为联接查询,联接查询的结果集或结果称为表之间的联接。

联接查询实际上是通过各个表之间共同列的关联性来查询数据的,它是关系数据库查询最主要 的特征。

4.2.1表联接类型

表联接类型可以分为内联接、外联接和交叉联接等。

1.内联接

内联接(inner join)是最常用的一种联接方式,只返回两个数据集合之间匹配关系的行,将位 于两个互相交叉的数据集合中重叠部分以内的数据行联接起来。 内联接使用比较运算符进行表间某(些)列数据的比较操作,并列出这些表中与联接相匹配的数据行

2.外联接

外联接(outer join)是对内联接的扩充,除了将两个数据集合中重复部分以内的数据行联接起 来之外,还可以根据要求返回左侧或右侧表中非匹配的数据或全部的数据

外联接分为以下几种。

1)左外联接

左外联接(left join 或 left outer join)的结果集包括左表的所有行,如果左表的某一行在右表中没有匹配行,则右表返回空值,否则返回相应值。

2)右外联接

右外联接(right join 或right outer join)是左外联接的反向联接,将返回右表的所有行,如果右 表的某一行在左表中没有匹配行,则左表返回空值,否则返回相应值。

3)全联接/完整外联接

全联接/完整外联接(full join 或full outer join)将返回左表和右表中的所有行,当某一行在另 一个表中没有匹配行时,另一个表返回空值,否则返回相应值。

3.交叉联接

交叉联接就是表之间没有任何关联条件,查询将返回左表与右表挨个联接的所有行,就是左表 中的每行与右表中的所有行再一一组合,相当于两个表"相乘"。

因为交叉联接应用场合较少,所以本课程不过多进行介绍,也不要求熟练掌握,如果感兴趣可 以查阅相关资料。

实验案例二:多表查询

实验环境

某公司有一台已经安装了SQLServer 2016的服务器,class数据库中包含products表和sales表. 表中内容分别如图1和图2所示。

图1

图2

需求描述

> 在products表和sales表中查询产品的名称,种类、成本,销售地点和销售价格。

> 在products表和sales表中查询销往海南的产品名称、种类、成本和销售价格。

> 在products表和sales表中查询销往北京的蔬菜名称、种类,成本和销售价格。

实验步骤

在products 表和 sales表中查询产品的名称、种类、成本,销售地点和销售价格。

复制代码
  select products.名称 名称products,products.种类 种类products,products.成本 成本products,sales.名称 名称sales,sales.销售地点 销售地点sales,sales.销售价格 销售价格sales
  from products inner join sales on products.名称=sales.名称

查询结果

在products表和sales表中查询销往海南的产品名称、种类、成本和销售价格。

复制代码
select products.名称 名称products,products.种类 种类products,products.成本 成本products,sales.名称 名称sales,sales.销售地点 销售地点sales,sales.销售价格 销售价格sales
from products inner join sales on products.名称=sales.名称
where 销售地点='海南'

查询结果

在products表和sales表中查询销往北京的蔬菜名称、种类,成本和销售价格。

复制代码
select products.名称 名称products,products.种类 种类products,products.成本 成本products,sales.名称 名称sales,sales.销售地点 销售地点sales,sales.销售价格 销售价格sales
from products inner join sales on products.名称=sales.名称
where 销售地点='北京' and 种类='蔬菜'

查询结果

相关推荐
auspicious航4 小时前
PostgreSQL 高可用与负载均衡
数据库·postgresql
路由侠内网穿透4 小时前
本地部署 SQLite 数据库管理工具 SQLite Browser ( Web ) 并实现外部访问
运维·服务器·开发语言·前端·数据库·sqlite
六毛的毛5 小时前
FastAPI入门:中间件、CORS跨域资源共享、SQL数据库
数据库·中间件·fastapi
菜萝卜子5 小时前
【Go】新版GORM自动字段映射规则
数据库·golang
哥哥还在IT中6 小时前
TiDB/MongoDB/Taosdb存储引擎概览
数据库·mongodb·tidb
vision_wei_6 小时前
Redis中间件(二):Redis协议与异步方式
网络·数据库·c++·redis·分布式·缓存·中间件
若梦plus6 小时前
PostgreSQL数据库基础
前端·数据库
茁壮成长的露露6 小时前
openGauss单实例安装
数据库·gaussdb
l1t6 小时前
利用DeepSeek改写并增强测试Duckdb和sqlite的不同插入方法性能
python·sql·sqlite·duckdb
代码的余温6 小时前
Redis内存耗尽时的应对策略
数据库·redis·缓存