MYSQL必知必会 | 查询相关
汇总数据
聚集函数
有时只需要汇总数据,并不需要把数据实际检索出来,所以MySql提供了专门的函数
聚集函数:运行在行组上,计算和返回单个值的函数
| 函数 | 说明 |
|---|---|
| AVG() | 返回某列平均值 |
| COUNT() | 返回某列的行数 |
| MAX() | 返回某列最大值 |
| MIN() | 返回某列最小值 |
| SUM() | 返回某列值之和 |
COUNT()中,如果指定列名,则忽略NULL值,如果为*,则不忽略NULL
AVG() \ MAX() \ MIN() \ SUM() 函数忽略列值为NULL的行使用 DISTINCT 参数,可以让聚合函数忽略相同的值
分组数据
主要介绍 group by 和 having
创建分组
使用 group by 创建分组
SELECT col_name_1, col_name_2
FROM table_name
Group by col_name_a,col_name_b
group by 子句可以包含任意数目的列
如果在 group by 子句中嵌套了分组, 数据将在最后规定的分组下进行会中
如果分组的列中具有NULL值,所有的NULL将被分成一个组返回
group by 子句必须在 where子句之后, order by子句之前
过滤分组
使用 having 过滤分组
having支持where的所有操作符
SELECT col_name
FROM table_name
GROUP BY col_name_a
HAVING condition
having 和 where 的差别
where在数据分组前进行过滤。where过滤的行不包含在分组中having在数据分组后进行过滤
分组和排序
我们有时需要 group by 以分组顺序输出,但实际情况并不总是这样。
所以我们需要使用 order by语句
使用子查询
- 子查询即嵌套在其他查询中的查询
- 对于嵌套的子查询数目没有限制,但是实际使用时由于性能的限制,不能嵌套太多的自查询
- 在 where 子句中使用自查询,应该保证 子查询的 select 语句具有与 where 子句中相同数目的列
- 相关子查询,涉及到外部查询的子查询。
联结表
基础知识
- 关系表
- 主键:可以唯一标识一行数据的属性
- 外键:定义两个表之间的联系,要么为空,要么为另一个表的主键
- 可伸缩性:能够适应不断增加的工作量而不失败的程度
使用联结的原因
为了有更好的可伸缩性,数据更有效、更方便的存储,我们将数据分解为多个表
数据存储在多个表中时,我们想要检索时,就需要联结多个表返回一个输出
创建链接
SELECT col_name_1, col_name_2, col_name_3
FROM table_name_1
WHERE table_name_1.col_name_a = table_name_2.col_name_b
当引用的列可能出现二义性时,必须使用完全限定列名,即表名+'.'+列名
如果不加入 where 子句,即没有联结条件,将返回两个表的笛卡尔积
内部联结
内部联结,又称等值联结
SELECT col_name_1, col_name_2
FROM table_name_1 INNER JOIN table_name_2
ON table_name_1.col_name_a = table_name_2.col_name_b
此处的 inner join 子句与 上面提到的 where 子句其相同的作用,但是使用明确的联结语法可以确保不会忘记联结条件,有时这样做也会影响到性能
MySql在运行时,关联指定的每个表以处理联结,这种处理非常消耗资源,所以,不要联结不必要的表,联结的表越多,性能下降的越厉害
自联结
SELECT a.col_name_1, a.col_name_2
FROM table_name as a, table_name as b
where a.col_name_a = b.col_name_a
自联结通常作为外部语句替代从相同表中检索数据时使用的子查询语句,虽然最终结果相同,但是处理联结比处理子查询快得多,应该试一下两种方式,以确定那种性能更好
自然连接
自然连接是一种特殊的内部联结,他要求两个表具有相同的属性列,同时在内部联结的基础上,去掉了重复的属性
外部链接
分为 左外连接 和 右外连接
连接时会产生一些在另一个表中没有数据的元组,这些元组成为悬浮元组
左外连接,使返回结果包含左边关系表联结后产生的的悬浮元组,这些元组在右边表的属性列值都为NULL
右外连接同上,两种类型的外连接可以互换使用,根据方便决定
注意事项
- 一般使用内部联结和外部链接
- 要保证使用正确的连接条件
- 应该总是提供联结条件(否则会出现笛卡尔积
- 在一个联结中可以包含多个表,对于每个联结可以采用不同的连接方式
组合查询
-
MySql允许执行多个查询,然后将结果作为单个查询结果集返回
-
这样的组合查询通常称为 并 或者 复合查询,使用
union关键字 -
需要使用组合查询的情况:
- 在单个查询中从不同的表返回类似结构的数据
- 对单个表执行多个查询,按单个查询返回数据
-
组合相同表的查询 = 具有多个 where 子句条件的单挑查询
- 这两种技术在不同的查询中性能不同,因此应该尝试两种方式,以确定对待特定的查询哪一种性能更好
UNION 规则
-
UNION 必须有两条即以上的 SELECT 语句组成
-
UNION 中的每个查询必须包含相同的列、表达式、聚合函数,但不需要各个列按照相同的次序列出
-
列数据类型不需要完全相同,但是一定要兼容,且使DBMS可以隐含转换的类型
-
UNION 会从查询结果集中自动去掉重复的行,如果想要返回所有的行,可以使用
union all关键字UNION ALL 完成了 WHERE 子句无法完成的工作 -
如果想对 UNION 组合查询进行排序,只能使用一条 ORDER BY 语句,且必须放在最后一条 SELECT 语句之后
相关文章:
MYSQL必知必会 | 查询相关
汇总数据 聚集函数 有时只需要汇总数据,并不需要把数据实际检索出来,所以MySql提供了专门的函数 聚集函数:运行在行组上,计算和返回单个值的函数 函数说明AVG()返回某列平均值COUNT()返回某列的行数MAX()返回某列最大值MIN()返…...
Java学习环境一站说明(保姆级详细教学)
1.Java开发环境搭建官网下载www.oracle.com2.安装注意:1.选择安装位置时尽量不要安装到C盘,路径中不要有空格以及中文的存在2.开发人员安装的jdk中包含了jre,所以不需要单独安装jre3.环境变量配置打开高级系统设置2.点击环境变量3.在系统变量…...
05-Oracle中的对象(视图,索引,同义词,系列)
本章主要内容: 1.视图管理:视图新增,修改,删除; 2.索引管理:索引目的,创建,修改,删除; 3.同义词管理:同义词的作用,创建࿰…...
如何通过websoket实现即时通讯+断线重连?
本篇博客只是一个demo,具体应用还要结合项目实际情况,以下是目录结构: 1.首先通过express搭建一个本地服务器 npm install express 2.在serve.js中自定义测试数据 const express require(express); const app express(); const http req…...
爽,我终于掌握了selenium图片滑块验证码
因为种种原因没能实现愿景的目标,在这里记录一下中间结果,也算是一个收场吧。这篇文章主要是用selenium解决滑块验证码的个别案列。 思路: 用selenium打开浏览器指定网站 将残缺块图片和背景图片下载到本地 对比两张图片的相似地方&#x…...
二、SpringMVC注解式开发
1. RequestMapping注解 此注解就是来映射服务器访问的路径 可加在方法上,是为此方法注册一个可以访问的名称(路径) 可以加在类上,相当于是包名(虚拟路径),区分不同类中相同的action的名称 可区分get请求和post请求 package com.powernode.controller;import org.springframe…...
Java容器面试知识点总结
容器 java容器有哪些? String,数组以及Java.util 下面的集合类 List:存放有序,列表存储,元素可重复 ArrayList LinkedList Vector Set:无序,元素不可重复 HashSet TreeSet Map: 无序,元素可重复…...
增长:2023 IT运维发展趋势前瞻
根据IDC和智研咨询数据等平台公开数据显示,从2018年至2022年,全球ITOM行业市场规模以8.58%的年均复合增长率高速增长。其中,中国ITOM市场在2020-2023年的年复合增长率为10.7%,到2023年市场规模将达到165.7亿元。012022中国IT运维解…...
自己定义typescript的类型声明文件xx.d.ts
****内容预警***菜鸟新手内容,大佬请绕道,不对的请指出我们在使用typescript的使用,如果安装一个包没有相应的类型声明文件,ts的类型检查就会报错,所以我们经常会安装npm包对应的types类型声明包,比如uuid …...
数据分析方法及名词解释总结_(面试2)
1、用户画像 1.1、什么是用户画像?如何构建用户画像? - 知乎提到用户画像, 很多人都可能存在的错误认知,即把用户画像简单理解成用户各种特征,比如说姓名、性别、…https://www.zhihu.com/question/372802348/answer/2…...
【FLY】Java知识点总结
目录认识Java概念图名词解释历史版本基础知识编程规范关键字数据类型运算符数组Stringequals与流程控制引用数据结构常用数据结构HashMapLinkedHashMapWeakHashMapIdentityHashMapEnumMapTreeMapCopyOnWriteArrayList面向对象类反射注解IO异常线程EffectiveJava8JVM运行时数据区…...
SpringMVC-0307
三、RequestMapping注解1、RequestMapping注解的功能从注解名称上我们可以看到,RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。SpringMVC 接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理…...
华为OD机试 - 九宫格按键输入(C 语言解题)【独家】
最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南)华为od机试,独家整理 已参加机试人员的实战技巧文章目录 使用说明本期题目:九宫格按…...
Oracle 11g RAC群集部署
Oracle 11g RAC群集部署 1.环境介绍: 操作系统:Oracle Enterprise Linux 6.5 Oracle数据库:Oracle 11.2.0.4 集群软件:Oracle Grid Infrastructure 11.2.0.4 2.所需介质: p13390677_112040_Linux-x86-64_1of7 p133…...
【C++、C++11】列表初始化、右值引用
文章目录📖 前言1. 统一的列表初始化1.1 { } 花括号初始化:1.2 std::initializer_list:2. 右值引用2.1 什么是左值和右值:2.2 右值的分类:2.3 左值引用和右值引用的比较2.3 右值的使用场景:2.4 新的类功能&…...
CMU15-445 Project.3总结
在线测试 Project #3 - Query Execution 以下是Project #3的网址,2022FALL的Project #3是实现一个查询执行,实现一系列算子,用于实现数据库内的SQL计算。项目中的 Query Execution 主要分为三个任务: Access Method Executors…...
002+limou+HTML——(2)HTML文档
000、前言 一般来说一个静态网页拥有四种元素:文字、图片、超链接、音频和视频(注意,即使在web网页中植入Javascript语言,也不一定是动态网页,真正的动态网页判断标准:是否和服务器产生交互) …...
红外传感器模块与 Arduino 连接
红外传感器模块与 Arduino 连接 原文地址 Arduino 红外传感器接口 红外**接近传感器或红外传感器它发射红外光以感知周围环境,并可用于检测物体的运动。由于这是一个无源传感器,它只能测量红外辐射。如果您曾经尝试过设计避障机器人或任何其他基于接近…...
NC xml配置文件不能生产java文件
在NC开发过程中,新增、或修改了xml文件,在开发工具eclipse中生成或重新生成Java文件,发现生成不了相对应的Java文件。如下图,选中xml文件后,右键点击SpringXml to Java 这种情况其实一般都是xml配置文件有问题&#…...
华为OD机试 - 五键键盘(C 语言解题)【独家】
最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南)华为od机试,独家整理 已参加机试人员的实战技巧文章目录 使用说明本期题目:五键键盘…...
解锁ComfyUI扩展潜能:工作流优化实战指南
解锁ComfyUI扩展潜能:工作流优化实战指南 【免费下载链接】ComfyUI-Custom-Scripts Enhancements & experiments for ComfyUI, mostly focusing on UI features 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Custom-Scripts 在AI绘画创作中&…...
视频高清低延时直播/音视频点播/云点播/云直播EasyDSS在校园教育/K12教育等各场景中的应用介绍
在线教育的核心竞争力,归根结底在于教学体验的优劣,而视频技术作为线上教学的核心载体,直接决定了教学体验的上限。随着在线教育行业的快速迭代,学员对线上课堂的要求愈发严苛:不仅需要高清流畅、稳定无卡顿的音视频传…...
动态间隙精准诊断:NHJX-13 型底盘间隙仪机动车底盘安全检测全方案
动态间隙精准诊断:NHJX-13 型底盘间隙仪机动车底盘安全检测全方案在机动车安全环保检测体系中,底盘间隙仪是诊断车辆转向机构、悬挂系统、传动部件间隙状况的核心设备,尤其对大中型客车、重中型货车等营运车辆,其性能直接决定底盘…...
Phi-3-mini-4k-instruct-gguf一键部署:VMware虚拟机Ubuntu系统安装全流程
Phi-3-mini-4k-instruct-gguf一键部署:VMware虚拟机Ubuntu系统安装全流程 1. 准备工作与环境搭建 在开始之前,我们需要准备好必要的软件和资源。这个教程适合那些习惯在虚拟化环境中工作的开发者,特别是需要在本地测试后再部署到生产环境的…...
OpenCore技术方案:老旧设备系统兼容性深度解析与性能优化评估
OpenCore技术方案:老旧设备系统兼容性深度解析与性能优化评估 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 1. 问题剖析:为何老旧Ma…...
基于Dify的AI数据采集与整理工具设计与实现
基于Dify的AI数据采集与整理工具设计与实现 1. 引言 1.1 背景与需求 在信息爆炸的时代,新闻网站、人物资料库等不断产生海量数据。传统手动采集整理方式效率低下,难以满足实时性、准确性和规模化的要求。本工具旨在利用Dify平台的强大编排能力,结合AI大语言模型(LLM)和…...
用ZYNQ PS-SPI给Flash测个速:华邦W25Q80在25MHz时钟下的真实读写性能报告
ZYNQ PS-SPI Flash性能深度评测:华邦W25Q80在25MHz时钟下的极限挖掘 当我们需要在嵌入式系统中选择一款Flash存储器时,数据手册上的理论参数往往无法反映真实应用场景下的性能表现。本文将基于Xilinx ZYNQ平台的PS-SPI接口,对华邦W25Q80 Flas…...
Pixel Aurora Engine 辅助UI/UX设计:自动生成界面原型与素材
Pixel Aurora Engine 辅助UI/UX设计:自动生成界面原型与素材 1. 设计效率的革命性提升 想象一下这样的场景:产品经理刚描述完"我们需要一个社交App的登录页,要简洁现代感,带点科技风",几分钟后,…...
终极指南:免费开源fSpy相机匹配工具,3分钟实现2D图像到3D场景的完美转换
终极指南:免费开源fSpy相机匹配工具,3分钟实现2D图像到3D场景的完美转换 【免费下载链接】fSpy A cross platform app for quick and easy still image camera matching 项目地址: https://gitcode.com/gh_mirrors/fs/fSpy 还在为将2D照片转换为精…...
Fluent Meshing体网格生成失败?别慌,先检查你的几何模型是不是‘点接触’了
Fluent Meshing体网格生成失败?别慌,先检查你的几何模型是不是‘点接触’了 当你在Fluent Meshing中看到体网格生成失败的红色报错提示时,那种感觉就像考试时突然发现漏做了一整页题目。特别是当截止日期迫在眉睫,这种报错往往让人…...
