当前位置: 首页 > news >正文

T-SQL的多表查询

        前面讲述过的所有查询都是基于单个数据库表的查询。如果一个查询需要对多个表进行操作,就称为联接查询,联接查询的结果集或结果称为表之间的联接。 联接查询实际上是通过各个表之间共同列的关联性来查询数据的,它是关系数据库查询最主要的特征。

表联接类型

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

1.内联接

        内联接(igmgr join)是最常用的一种联接方式,只返回两个数据集合之间匹配关系的行,将位 于两个互相交叉的数据集合中重叠部分以内的数据行联接起来。

        内联接使用比较运算符进行表间某(些)列数据的比较操作,并列出这些表中与联接相匹配的数据行。

 

2.外联接

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

外联接分为以下几种:

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

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

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

根据联接查询的两个数据集合按照其出现位置的不同,可以将两个表分别定义为左侧表(左表)和右侧表(右表)。

3.交叉联接

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

实验案例:

84acbf99c0514579a1af3f2cce77b43d.pngf6b629d8e8f1443a97ac41cfa032721d.png

需求描述

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

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

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

 

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

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

5876251ac47a4760b2e47e156fe32531.png

 

2/查询销往海南的产品名称、种类、成本和销售价格。

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

d5f7f7fb8db54dc590a2295183608e7c.png

 

3/查询销往北京的蔬菜名称、种类、成本和销售价格。

select products.名称 名称products,products.种类 种类products,products.成本 成本products,sales.销售价格 销售价格sales
from products inner join sales on products.名称=sales.名称
where 销售地点='北京'

bde3c5aaec28414f95e1100d7ccabdbf.png

 

 

 

http://www.lryc.cn/news/252284.html

相关文章:

  • 适合学生备考的护眼台灯有哪些?五款公认优质台灯推荐
  • 机器人学英语
  • 51综合程序03-DS1302时钟
  • redis的缓存击穿,缓存穿透,缓存雪崩
  • AutoHotKey-study
  • Go to do list
  • JWT 认证机制
  • 内核启动时间信息打印
  • Web端专业级H264/H265 直播流播放器实现-JessibucaPro播放器
  • macOS sandbox 文件夹授权
  • CentOS 7安装Java 8
  • 施密特正交
  • 视频号小店怎么起量?实操详解!
  • 如何将unity项目托管到github(快速便捷)
  • ClickHouse(16)ClickHouse日志引擎Log详细解析
  • opencv项目开发实战--填补字母的空白
  • Wnmp本地搭建结合内网穿透实现远程访问本地Wnmp服务
  • C++ 红黑树的封装
  • MongoDB快速入门及其SpringBoot实战
  • Python网络爬虫练习
  • 《opencv实用探索·九》中值滤波简单理解
  • PC行内编辑
  • 鸿蒙开发:Stage模型开发-应用/组件级配置以及UIAbility组件初步使用【鸿蒙专栏-20】
  • Django回顾【五】
  • Python容器——字典
  • 基于Java SSM框架实现实现四六级英语报名系统项目【项目源码+论文说明】
  • 翻硬币(第四届蓝桥杯省赛C++B组)(java版)
  • 原生GPT本地及云端部署方式保姆级教程
  • Docker容器(一)概述
  • Facebook引流怎么做?写个脚本就好!