高级查询(一)

解决需求:Excel都可以轻松搞定

分组查询原理: 

语法: SELECT …<列名>

FROM <表名>

[WHERE<条件表达式> ] 

GROUP BY

参与分组的列 可以与 聚合函数作用的列 一块显示

注意 SELECT列表中只能包含:

1、被分组的列

2、其它返回一个值的表达式,如聚合函数


一、单列分组
-- 统计各年级的人数
select * from Student
select count(*) from student where GradeId=1;
select count(*) from student where GradeId=2;
select count(*) from student where GradeId=3;
select count(*) from student where GradeId=4; -- 之前的方式
-- 使用GROUP BY进行分组查询
select COUNT(StudentNo) as 人数, Gradeid 班级 from Student as 学生表 GROUP BY
Gradeid;
where 子句
sql 语句中使用 group by 这个子句实现分组,用 where 子句实现查询数据的过滤,在分组中需要过滤数据那么group by 跟在 where 子句后面。
--1 2 3 年级分别的平均成绩(带数据过滤的分组)
select * from result;
select AVG(StudentResult) 平均分,Subjectid as 年级 from Result where Subjectid
in(1,2,3)
group by Subjectid;
order by 子句
-- 123年级平均分 按平均成绩高低显示
-- 依然可以用order by 对我们的分组结果进行排序
-- (带数据过滤的分组 并排序)
select AVG(StudentResult) 平均分,Subjectid as 班级 from Result where Subjectid
in(1,2,3)
group by Subjectid order by AVG(StudentResult) desc;
having 子句
-- 筛选分组结果显示 having
-- 各班的所有学生平均成绩 良好 按低到高排列
select AVG(StudentResult) 平均分,Subjectid as 班级 from Result group by
Subjectid
having AVG(StudentResult)>=70 order by AVG(StudentResult);
书写顺序及说明:
select..... from...where( 过滤操作的数据 )
group by (分组操作)
having ( 筛选显示分组后的结果 )
....order by ( 对最后的分组结果进行排序 )
WHEREHAVING对比
WHERE 子句:用来筛选 FROM 子句中指定条件的数据行 , GROUP BY 子句:用来分组 WHERE 子句的
输出数据
HAVING 子句:用来从分组的结果中筛选数据

二、多列分组
解决需求: 对各年级学生再次进行分组,计算每组学生的总人数
--对多列进行分组 group by 后多列之间用,号就可了
--查询1 2 3班级 男 女 人数
select COUNT(StudentNo) as 人数,Sex 性别,Gradeld 班级 from Student where
Gradeld in(1,2,3)
group by Gradeld, Sex order by Gradeld

完整查询语法:
SELECT …… FROM < 表名 >
[WHERE] ……
[GROUP BY] ……
[HAVING].....
[ORDER BY]...

三、多表查询

解决需求:
--查分数 查询名字 需要多张表查询操作
select * from Student;
select * from Result;
select StudentResult 分数 from Result;
select StudentName 名字 from Student;

1、内联接
左右两张表联合查询,根据联合条件两张表都满足条件的数据被查询显示
A 、简单写法
语法
SELECT ……
FROM 1 ,表 2
WHERE …… 1.xxx= 2.xxxx( 连接条件必写 )
select a.* ,b.GradeName from Subject a,Grade b
where a.GradeId = b.GradeId;
select r.StudentResult 分数,s.* from Result r,Student s
where s.StudentNo=r.StudentNo;
B、关键字写法
语法:
SELECT ……
FROM 1
INNER JOIN 2
ON …… 连接条件
select a.* ,b.GradeName from Subject a inner join Grade b
on a.GradeId = b.GradeId;
select r.StudentResult 分数,s.* from Result r inner join Student s
on r.StudentNo=s.StudentNo;
三表联接
--三表查询 在上面的基础上请查询出相应科目的名字
select a.*,b.StudentName 名字,c.SubjectName 科目 from
Result a,Student b,Subject c
where a.StudentNo = b.StudentNo and a.SubjectId =c.SubjectId;
select r.*, s.SubjectName 科目名,c.StudentName from result as r inner join
`subject` as s inner join student c on r.SubjectId= s.SubjectId and
r.StudentNo = c.StudentNo;
2、外联接
A、左外联接
左外联接是以左表为基础的,左表的记录将会全部表示出来,而右表只会显示符合搜索条件的记录,右表记录不足的地方均为null
语法
SELECT ……
FROM 1
left JOIN 2
ON …… 连接条件
-- left join on
select * from Subject;
select * from Result;
-- 查询学号科目 成绩
select a.StudentNo 学号,a.SubjectId 科目号,a.StudentResult 成绩 ,b.SubjectName
from Result a left join Subject b
on a.SubjectId = b.SubjectId;
select a.*,b.GradeName 年级名称 from Student a left join Grade b
on a.GradeId = b.GradeId;
B、右外联接
右外联接是以右表为基础的,右表的记录将会全部表示出来,而左表只会显示符合搜索条件的记录,左表记录不足的地方均为null
语法
SELECT ……
FROM 1
right JOIN 2
ON …… 连接条件
-- 右外连接 right join on
select a.StudentNo 学号,a.StudentResult 成绩,b.StudentName 姓名
from Student b right join Result a
on a.StudentNo = b.StudentNo;
select a.* ,b.GradeName 年级名称 from Subject a right join Grade b
on a.GradeId = b.GradeId;

左表不符合条件的地方 填充 null
C 、全外联接(很遗憾 mysql 不支持,其它数据库有)
执行规则:返回左表和右表中的所有行,当某行在另一表中没有匹配行,则另一表中的列返回空值

 语法:

SELECT ……

FROM 表1

FULL OUT JOIN 表2

ON ……连接条件

select a.StudentNo 学号,a.SubjectId 科目号,a.StudentResult 成绩 ,b.SubjectName
from Result a full OUT join Subject b
on a.SubjectId = b.SubjectId
select a.* ,b.GradeName from Subject a full OUT join Grade b
on a.GradeId = b.GradeId

感谢大家的阅读,如有不对的地方,可以私信我,感谢大家!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux中如何配置虚拟机网络(NAT方法)

首先我们要在Linux中找到配置文件的路径/etc/sysconfig/network-scripts/&#xff0c;然后找到配置文件的名称ifcfg-xxx&#xff08;如&#xff1a;ifcfg-ens33&#xff09;&#xff0c;然后打开这个文件内 容如下&#xff1a; TYPEEthernet # 指定网卡类型是以太网 BOOTPROT…

gin框架学习笔记(三) ——路由请求与相关参数

参数种类与参数处理 查询参数 在讲解查询参数的定义之前&#xff0c;我们先来看一个例子&#xff0c;当我打开了CSDN&#xff0c;我现在想查看我的博客浏览量&#xff0c;那么我就需要点击我的头像来打开我的个人主页,像下面这样: 我们现在把浏览器的网址取下来&#xff0c;…

分布式版本控制工具git

1 安装Git 在linux上我们建议你用二进制的方式来安装git&#xff0c;可以使用发行版包含的基础软件包管理工具来安装&#xff0c;如果你是 是CentOS或者Fedora的操作系统&#xff0c;可以使用yum命令来安装git&#xff1a; $ sudo yum install git如果你是ubuntu或者是Debian…

YOLOv9独家原创改进: 特征融合创新 | 一种基于内容引导注意力(CGA)的混合融合 | IEEE TIP 2024 浙大

💡💡💡创新点:提出了一种基于内容引导注意力(CGA)的混合融合方案,将编码器部分的低级特征与相应的高级特征有效融合。 💡💡💡在多个数据集实现暴力涨点,适用于小目标,低对比度场景 💡💡💡如何跟YOLOv9结合:将backbone和neck的特征融合,改进结构图如下…

sql实践

1.从excel导入数据 在excel导入数据时要先在数据库中创建对应的数据库表 CREATE TABLE your_table_name (crawl_datetime DATE,url CHAR(255),company_name CHAR(255),company_size CHAR(255),company_type CHAR(255),job_type CHAR(255),job_name CHAR(255),edu CHAR(255),e…

LLM推理入门指南③:剖析模型性能

在本系列文章《LLM推理入门指南①&#xff1a;文本生成的初始化与解码阶段》中&#xff0c;作者对Transformer解码器的文本生成算法进行了高层次概述&#xff0c;着重介绍了两个阶段&#xff1a;提示的处理阶段和逐个生成补全词元的多步生成阶段。在上一篇文章《LLM推理入门指南…

【递归、回溯和剪枝】综合训练<二>

1.组合总和 组合总和 解法一&#xff1a; class Solution { public:vector<vector<int>> ret;vector<int> path;int aim;vector<vector<int>> combinationSum(vector<int>& nums, int target) {aim target;dfs(nums, 0, 0);return …

整合Tess4J图文识别技术

1. OCR图文识别介绍 OCR&#xff08;全称 Optical Character Recognition&#xff0c;直译为光学字符识别&#xff09;用于图片文字识别&#xff0c;例如 提取图片中车牌号等等。 Java中实现OCR的技术方案有&#xff1a; 百度OCR&#xff0c;花米Tesseract-OCR&#xff0c;Go…

文心一言 VS 讯飞星火 VS chatgpt (259)-- 算法导论19.3 2题

二、使用聚合分析来证明 FIB-HEAP-DECREASE-KEY 的 O(1) 摊还时间是每一个操作的平均代价。如果要写代码&#xff0c;请用go语言。 文心一言&#xff1a; FIB-HEAP-DECREASE-KEY 是斐波那契堆&#xff08;Fibonacci Heap&#xff09;操作中的一个&#xff0c;它允许我们减少堆…

【LangChain系列 15】语言模型——LLMs(一)

原文地址&#xff1a;【LangChain系列 15】语言模型——LLMs(一) 本文速读&#xff1a; 异步API 自定义LLM Fake LLM HumanInput LLM 本文将介绍LLMs在LangChain中的一些用法&#xff0c;帮助我们更好地了解LLM模块。 01 异步API LangChain通过异步库实现了对异步的支持&a…

楼宇智慧公厕建设新方案-集成更简单!成本价更低!

在当今的大厦和写字楼中&#xff0c;公厕面临着诸多痛点。 办公楼公厕常常存在厕位难找的问题&#xff0c;使用者不得不花费时间逐一查看&#xff0c;导致效率低下&#xff1b;环境质量也令人担忧&#xff0c;异味、脏污等情况时有发生&#xff0c;影响使用者的心情和健康&…

深入探索Android签名机制:从v1到v3的演进之旅

引言 在Android开发的世界中&#xff0c;APK的签名机制是确保应用安全性的关键环节。随着技术的不断进步&#xff0c;Android签名机制也经历了从v1到v3的演进。本文将带你深入了解Android签名机制的演变过程&#xff0c;揭示每个版本背后的技术细节&#xff0c;并探讨它们对开…

创意无限!AI一键生成漫画视频,每天轻松收入300+,粘贴复制简单操作!

AI项目算是2023到2024一直都非常火爆的项目&#xff0c;这次的AI漫画项目也是相当暴利的项目了&#xff0c;我知道一个老铁通过AI漫画半年已经获利100W了&#xff0c;真的是相当暴利了。 不再多说&#xff0c;直接上手拆解项目。 项目获取&#xff1a; https://zzmbk.com/htt…

linux 任务管理(临时任务定时任务) 实验

目录 任务管理临时任务管理周期任务管理 任务管理 临时任务管理 执行如下命令添加单次任务&#xff0c;输入完成后按组合键Ctrl-D。 [rootopenEuler ~]# at now5min warning: commands will be executed using /bin/sh at> echo "aaa" >> /tmp/at.log at&g…

C++|二叉搜索树

一、二叉搜索树的概念 二叉搜索树又称为二叉排序树&#xff0c;它或者是一颗空树&#xff0c;或者是具有以下性质的二叉树&#xff1a; 若它的左子树不为空&#xff0c;则左子树上所有节点的值小于根节点的值若它的右子树不为空&#xff0c;则右子树上所有节点的值都大于根结…

AVL树、红黑树

数据结构、算法总述&#xff1a;数据结构/算法 C/C-CSDN博客 AVL树 定义 空二叉树是一个 AVL 树如果 T 是一棵 AVL 树&#xff0c;那么其左右子树也是 AVL 树&#xff0c;并且 &#xff0c;h 是其左右子树的高度树高为 平衡因子&#xff1a;右子树高度 - 左子树高度 创建节点…

图片标签 以及 常见的图片的格式

1.图片的基本使用 2.图片的常见格式 3.bmp格式

易我分区大师18.5发布上线:全方位提升您的磁盘管理体验

近期&#xff0c;易我分区大师18.5版本正式发布上线&#xff01; 新版本在原有基础上进行了升级和优化&#xff0c;不仅继承了前版本的强大功能&#xff0c;还新增了C盘数据迁移、清除Windows PIN码以及蓝屏问题助手等实用功能&#xff0c;帮助用户更轻松、更高效地管理电脑磁…

HTML的使用(中)

文章目录 前言一、HTML表单是什么&#xff1f;二、HTML表单的使用 &#xff08;1&#xff09;<form>...</form>表单标记&#xff08;2&#xff09;<input>表单输入标记总结 前言 在许多网页平台上浏览&#xff0c;大多逃不了登录账号。此时在网页中填写的用户…

数据库SQL编写规范-SQL书写规范整理(SQL语句书写规范全解-Word原件)

编写本文档的目的是保证在开发过程中产出高效、格式统一、易阅读、易维护的SQL代码。 1 编写目 2 SQL书写规范 3 SQL编写原则 软件全套精华资料包清单部分文件列表&#xff1a; 工作安排任务书&#xff0c;可行性分析报告&#xff0c;立项申请审批表&#xff0c;产品需求规格说…