数据库SQL查询(二)之连接查询

news2025/1/17 6:07:16

本文介绍SQL查询,如何在海量数据中筛选想要数据;

数据库管理系统选择:关系型数据库mysql

数据库管理工具选择:navicat

本文中查询语句和查询案例参考自:https://edu.csdn.net/course/detail/27673?ops_request_misc=&request_id=&biz_id=105&utm_term=SQL&utm_medium=distribute.pc_search_result.none-task-course-2~course~sobaiduweb~default-3-27673.pc_edu_default&spm=1018.2226.3001.4453
 

目录

连接查询

认识几种连接类型

内连接 (Inner Join)

外连接--左外连接 (Left Outer Join)

外连接--右外连接 (Right Outer Join)

交叉连接(CROSS JOIN)

示例

示例一(Inner Join)

示例二(Left Outer Join)

示例三(CROSS JOIN)


连接查询

将多张表(至少两张)按照某个连接条件连接成一张大表,在大表中执行查询;

本文为SQL99标准的写法

认识几种连接类型

准备2张表

 

内连接 (Inner Join)

按照连接条件进行连接,满足条件的显示在大表中,不满足的隐藏;

大部分查询都是内连接;

SELECT
	* 
FROM
	Table1
	INNER JOIN Table2 ON Table1.SNo = Table2.SNo

 

外连接--左外连接 (Left Outer Join)

Left左边的表为主表,按照连接条件在右边的表中匹配数据,匹配上的直接显示在大表中,匹配不上的显示null;

SELECT
	* 
FROM
	Table1
	LEFT OUTER JOIN Table2 ON Table1.SNo = Table2.SNo

外连接--右外连接 (Right Outer Join)

Right右边的表为主表,按照连接条件在左边的表中匹配数据,匹配上的直接显示在大表中,匹配不上的显示null;

SELECT
	* 
FROM
	Table1
	RIGHT OUTER JOIN Table2 ON Table1.SNo = Table2.SNo

交叉连接(CROSS JOIN)

返回被连接的两个表所有数据行的笛卡尔积;

主要目的是为了组合数据;

SELECT
	* 
FROM
	Table1
	CROSS JOIN Table2

 

示例

示例一(Inner Join)

-- 查询陈鹏借了哪些书

(在数据库SQL查询(一)中,我们用嵌套查询实现了这个需求,在此处我们用连接查询实现这个需求,看看有什么不同;)

1、表关系如下图所示:

2、先把3张表连接为一张大表

SELECT
	* 
FROM
	Student
	INNER JOIN BorrowBook ON BorrowBook.SNO = Student.SNO
	INNER JOIN Book ON Book.BookID = BorrowBook.BookID

 3、再从这张大表中筛选条件满足数据

SELECT
	BookName 
FROM
	Student
	INNER JOIN BorrowBook ON BorrowBook.SNO = Student.SNO
	INNER JOIN Book ON Book.BookID = BorrowBook.BookID 
WHERE
	sname = '陈鹏'

示例二(Left Outer Join)

-- 统计出借书库存情况 
/*
     图书编号    图书名称    入库量    被借量
        -------------------------------------------------
       39001    Mysql数据库     15           6    
*/

1、表关系为:

2、 这里表连接之前,分析:

book表中有3个值可以直接得到;

borrowbook表中想要得到被借量,需要分组查询,用分组后的新表 重命名(AS)后,与book表进行连接;

Left Outer Join中的outer可以省略;

SELECT
	* 
FROM
	Book
	LEFT JOIN ( SELECT BookID, COUNT(*) AS num FROM BorrowBook GROUP BY BookID ) AS nums ON nums.BookID = Book.BookID

 

 3、得到大表后,被借量num列,有null数据,代表这本书没有被借过,用0代替(用ifnull函数)

SELECT
	Book.BookID AS '图书编号',
	BookName AS '图书名称',
	BookIncoming AS '入库量',
	IFNULL( num, 0 ) AS '被借量' 
FROM
	Book
	LEFT JOIN ( SELECT BookID, COUNT(*) AS num FROM BorrowBook GROUP BY BookID ) AS nums ON nums.BookID = Book.BookID

 

示例三(CROSS JOIN)

-- 统计出哪些学生的哪些科目缺考

 

SELECT
	* 
FROM
	( SELECT * FROM Stu CROSS JOIN Course ) AS T1
	LEFT JOIN Score ON T1.SNO = Score.SNo 
	AND T1.CNo = Score.CNo 
WHERE
	Result IS NULL

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

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

相关文章

python django vue httprunner 实现接口自动化平台(最终版)

一、项目介绍: 1.1 项目地址 前端地址: GitHub - 18713341733/test_platform_service: django vue 实现接口自动化平台 后端地址: GitHub - 18713341733/test_platform_front: Django vue实现接口自动化平台 1.2 项目介绍 1.2.1 环境…

在 K8S 中部署一个应用 上

本身在 K8S 中部署一个应用是需要写 yaml 文件的,我们这次简单部署,通过拉取网络上的镜像来部署应用,会用图解的方式来分享一下,过程中都发生了什么 简单部署一个程序 我们可以通过 kubectl run 的方式来简单部署一个应用&#…

Python深度学习027:什么是梯度、梯度消失、梯度爆炸以及如何解决

文章目录 1. 梯度的概念2. 梯度更新中存在的问题2.1 梯度消失2.2 梯度爆炸3. 解决办法3.1 梯度消失3.2 梯度爆炸1. 梯度的概念 在机器学习中,梯度是指一个多元函数在某一点处的变化率以及变化的方向。 对于一个参数化的函数,梯度可以告诉我们在一个特定的点处函数值增加最快…

分布式系统概念和设计——Mach实例研究

分布式系统概念和设计 Mach实例研究 Mach主要抽象概述 任务 一个Mach任务是一个执行环境主要包括一个被保护的地址空间和一个内存管理的权能集合这些权能主要用于访问端口 线程 任务可以包含多个线程在共享内存的多处理器中,属于同一个任务的线程可以在不同的处理…

【案例实战】SpringBoot整合Redis实现缓存分页数据查询

正式观看本文之前,设想一个问题,高并发情况下,首页列表数据怎么做? 类似淘宝首页,这些商品是从数据库中查出来的吗?答案肯定不是,在高并发的情况下,数据库是扛不住的,那么…

Java解析XML文件(DOM4J解析xml文件)

内容重点1:DOM4J创建、解析、修改XML文件 内容重点2:DOM4J模拟解析web.xml配置文件,实现实例化servlet 1、什么是xml Xml(Extensible Markup Language) 一种扩展性标示语言,出现的意义其实与JSON字符串的意义相似,是新一代的数据交换标准…

怎么加密共享文件夹?局域网共享文件夹加密方法

相信很多企业都在使用局域网共享文件夹,它可以很方便地实现各部门之间的沟通协作。但是由于使用人员众多,数据安全非常难以得到保障。那么我们该怎么加密局域网共享文件夹呢? 共享文件夹加密 首先,我们先来了解一下共享文件夹加密…

某农业大学数据结构A-第13周作业

1.拓扑排序 【问题描述】 拓扑排序的流程如下: 1. 在有向图中选一个没有前驱的顶点并且输出之; 2. 从图中删除该顶点和所有以它为尾的弧。 重复上述两步,直至全部顶点均已输出,或者当前图中不存在无前驱的顶点为止。后一种情况则…

渲染模式差异和选择

传统服务端渲染 在过去传统开发中,页面渲染任务是由服务端完成的,服务器负责获取数据,拼装页面,客户端仅负责内容显示,使用这种方式的典型技术有 JSP、PHP、ASP.NET 等等。 客户端渲染 CSR Vue.js、React 这类框架之…

专访蘑菇物联沈国辉:做工业AI时代的推动者

在中国制造迈向高质量发展的进程中,数智化转型会成为破局之道。在这其中,蘑菇物联除了是一个本分的答题者,还是一个善于发现问题的贡献者。 作者|思杭 编辑|皮爷 出品|产业家 从广州造纸厂到广州造船厂,从第一橡胶厂到电池厂&a…

利用R语言通过百度地图API进行批量地理编码

利用R语言通过百度地图API进行批量地理编码 当您有大量的地点名称需要在地图上来呈现时,首先要在在线地图上找到该地址的坐标,通常是指经纬度,如果能够用代码来实现,便少了许多费时费力的体力活儿,以下将详细介绍地理…

数据结构的一些总结---利用Python实现

大家好,我是北山啦,本文简单介绍Python数据结构的相关内容,简单就是很简单的那种 文章目录 查找线性查找 O(n)二分查找(Binary Search) O(logn) 排序排序Low B三人组冒泡排序选择排序插入排序 排序NB三人组快速排序归并排序 数据结构栈和队列…

[Day 3 of 17]Building a document scanner in OpenCV

a computer vision-powered document scanner 计算机视觉驱动的文档扫描仪,三个步骤: 边缘检测edges通过边缘,找到代表待扫描纸张的轮廓contour应用透视转换(a perspective transform)获得文档自上而下的视图 How to Build a Kick-Ass Mob…

录音转文字的方法有哪些?这三个录音转文字的方法有哪些

你是否曾经遇到过这样的场景:在开会或者采访时,需要记录重要信息,但是手写记录或打字速度跟不上对话节奏,甚至难以记录所有细节。此时,录音转文字软件就派上用场了。然而,市场上有太多种选择,到…

【Vue3 生态】Vue Router 路由知识概览

前言 在 Web 前端开发中,路由是非常重要的一环,但是路由到底是什么呢? 从路由的用途上讲 路由是指随着浏览器地址栏的变化,展示给用户不同的页面。 从路由的实现原理上讲 路由是URL到函数的映射。它将 URL 和应用程序的不同部分…

低代码平台——提高研发效率的神器

一、前言 听起来像是一个噱头,但是低代码确实是一个能够快速提高研发效率的神器。 通过使用低代码平台,研发人员可以节省好几个月的时间,将前后端各种功能可视化以搭积木的形式快速完成。今天,我们将深入探讨低代码开发平台的特点…

两阶段目标检测指南:R-CNN、FPN、Mask R-CNN

动动发财的小手,点个赞吧! Source[1] 多阶段(Two-stage)物体检测 计算机视觉中最基本和最广泛研究的挑战之一是目标检测。该任务旨在在给定图像中绘制多个对象边界框,这在包括自动驾驶在内的许多领域非常重要。通常&am…

一种看门狗复位电源的电路

如下是一个看门狗复位电源的电路: 满足掉电能被监测到,掉电后利用法拉电容保持后级模组继续工作一段时间。 看门狗可以关闭电源 320ms 20ms ,对后级模组起到断电复位作用。 同时复位电源拉低的是VCC_4V 而非超级电容所在的VCC_4V_IN,并不会…

SpringBoot项目的事务实现

说明:当业务中的某个功能,需要多个操作组合执行才能完成时(如删除部门,部门下的员工也需要同步删除时),为了保证数据的一致性,需要对这些组合操作添加事务。(参考:http:/…

从电源 LED 读取智能手机的秘密?

研究人员设计了一种新的攻击方法,通过记录读卡器或智能手机打开时的电源 LED,使用 iPhone 摄像头或商业监控系统恢复存储在智能卡和智能手机中的加密密钥。 众所周知,这是一种侧信道攻击。 通过密切监视功耗、声音、电磁辐射或执行操作所需…