SQL分组查询(Oracle)及SQL完整的查询语句

news2024/10/6 6:47:07

文章目录

    • dql--数据查询语言
      • 简单查询
      • 条件查询
      • 排序查询
      • 分组查询
        • 分组函数(聚合函数)
        • 分组查询
      • 完整的查询语句
        • ==执行顺序==!
    • DML--数据操纵语言
    • DDL--数据定义语言
    • dcl--数据控制语言
    • tcl--事务控制语言

dql–数据查询语言

简单查询

SQL简单查询

条件查询

SQL条件查询

排序查询

SQL排序查询

分组查询

分组函数(聚合函数)

sum(列名) --求和
AVG(列名) --求平均
MIN(列名) --求最小
MAX(列名) --求最大
COUNT(列名 | * |数字) --计数
例题:
查询emp表所有员工的平均薪资;

SELECT AVG(sal) FROM emp;

在这里插入图片描述
注意:空值不参与聚合函数的统计

SELECT COUNT(comm),COUNT(*),COUNT(1) FROM emp;

在这里插入图片描述
放具体列的时候,统计的是该列非空值的个数。如comm统计数只有4 因为有奖金的人只有四个。

分组查询

根据要求,按照规则分组,统一分析各组的情况,每一组返回一个值

SELECT *|列名|常量|计算|函数
  FROM 表名
    WHERE 过滤条件
      GROUP BY 分组内容
        HAVING 过滤条件
          ORDER BY 排序内容 ASC|DESC;

例题:
查询每个部门的平均工资

SELECT AVG(sal) FROM emp GROUP BY deptno;

当SELECT后面出现聚合函数的时候,只能展示GROUP BY后面有的字段。

例题:
查询每个部门的每个岗位平均工资

SELECT deptno,job,AVG(sal)
	FROM emp
		GROUP BY deptno,job;

在这里插入图片描述
GROUP BY 后面可以跟多个字段,先按第一个字段分组,每组下面再按第二列分组…
练习:
查询工资大于2000的员工中,每个部门的每个岗位平均工资

SELECT deptno,job,AVG(sal)
	FROM emp
		WHERE sal>2000
			GROUP BY deptno,job;

在这里插入图片描述
练习:
查询工资大于2000的员工中,每个部门的每个岗位平均工资,要求平均薪资大于3000.结果按照平均工资降序。

SELECT deptno,job,AVG(sal) 
	FROM emp
		WHERE sal > 2000
			GROUP BY deptno,job
				HAVING AVG(sal)>3000
					ORDER BY AVG(sal) DESC;

HAVING是对分组后的数据进行过滤,WHERE是对分组前的数据进行过滤,WHERE后面不能使用聚合函数,如果使用WHERE AVG() …会报错。只要记住,但凡分组条件带聚合函数,就放 HAVING后。
整点练习题:
1.统计除10号部门的其他部门中,哪些部门的最高薪资达到三千
2.查询平均薪资超过1800的部门,显示部门编号及平均薪资
3.查询薪资合计超过5000的岗位及其平均薪资
4.查询部门人数超过4人的部门编号及薪资合计
5.查询各部门下,人数超过两人的岗位有哪些,显示部门编号、岗位名称
6.查询姓名重复的员工的姓名

SELECT deptno 
	FROM emp 
		WHERE deptno !=10 
			GROUP BY deptno 
				HAVING MAX(sal)>=3000;
SELECT deptno,AVG(sal) 
	FROM emp 
		GROUP BY deptno 
			HAVING AVG(sal)>1800;
SELECT job,AVG(sal) 
	FROM emp 
		GROUP BY job 
			HAVING SUM(sal)>5000;
SELECT deptno,SUM(sal) 
	FROM emp 
		GROUP BY deptno 
			HAVING COUNT(deptno)>4;
SELECT deptno,job 
	FROM emp 
		GROUP BY deptno,job 
			HAVING COUNT(job)>2;
SELECT ename 
	FROM emp 
		GROUP BY ename 
			HAVING COUNT(ename)>=2;

完整的查询语句

SELECT *|列名|常量|计算|函数
  FROM 表名
    WHERE 分组前的过滤条件(不能使用聚合函数的条件)
      GROUP BY 分组内容
        HAVING 过滤条件(分组后的过滤条件,能使用聚合函数的条件)
          ORDER BY 排序内容 ASC|DESC;

上述语法是数据库的书写顺序

执行顺序

1.FROM
2.WHERE
3.GROUP BY
4.HAVING
5.SELECT
6.ORDER BY
要记住!
拿别名来举例,ORDER BY后可以加别名 ,是因为他位于取别名的SELECT之后,而WHERE不能使用别名,是因为他执行在SELECT之前。
做个练习吧
1.查询 1982年以前入职的员工,按部门、岗位分组,查出
平均薪资超过800的部门和岗位类型及其平均薪资和最高薪资,按最高薪资降序排列
2.查询部门人数超过3的部门的部门编号、最高薪资、最低薪资、部门人数,按部门人数升序排列
3.查询岗位名称不以S开头、并且岗位平均薪资超过2000的岗位的岗位名称、岗位人数、岗位平均薪资,按岗位平均薪资升序排列
4.查询各部门部门编号、最高薪资、最低薪资,以及最高和最低薪资的差值,按部门编号降序排列
5.统计岗位类型、最高薪资、最低薪资、薪资合计、平均薪资,以及人数,
各字段以中文列名展示
6.统计薪资在1000到3000之间的人员中,有佣金的员工总数及无佣金的员工总数,

SELECT deptno,job,AVG(sal),MAX(sal) 
	FROM emp 
		WHERE hiredate < to_date('1982/1/1','yyyy/mm/dd') 
			GROUP BY deptno,job HAVING AVG(sal)>800 
				ORDER BY MAX(sal) DESC;
SELECT deptno,MAX(sal),MIN(sal),COUNT(1) 
	FROM emp 
		GROUP BY deptno 
			HAVING COUNT(1)>3;
SELECT job,COUNT(1),AVG(sal) 
	FROM emp 
		WHERE job NOT LIKE 'S%' 
			GROUP BY job 
				HAVING AVG(sal)>2000 
					ORDER BY AVG(sal) ASC; 
SELECT deptno,MAX(sal),MIN(sal),(MAX(sal)-MIN(sal)) 
	FROM emp 
		GROUP BY deptno 
			ORDER BY deptno DESC;
SELECT job "岗位类型",MAX(sal) "最高薪资",MIN(sal) "最低薪资",SUM(sal) "薪资合计",AVG(sal) "平均薪资",COUNT(1) "人数" 
	FROM emp 
		GROUP BY job;
SELECT COUNT(comm),COUNT(1)-COUNT(comm) 
	FROM emp 
		WHERE sal BETWEEN 1000 AND 3000;

DML–数据操纵语言

DML数据操纵语言

DDL–数据定义语言

未更新

dcl–数据控制语言

未更新

tcl–事务控制语言

未更新

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

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

相关文章

JavaWeb--前端--03Vue入门

Vue入门 1 Vue概述2 快速入门3 Vue指令3.1 v-bind和v-model3.2 v-on3.3 v-if和v-show3.4 v-for3.5 案例 4 生命周期 1 Vue概述 个完整的html页面包括了视图和数据&#xff0c;数据是通过请求 从后台获取的&#xff0c;那么意味着我们需要将后台获取到的数据呈现到页面上&#…

Redis-键值设计

Redis-键值设计 1.设置key的规范 遵循基本格式&#xff1a;【业务名称】&#xff1a;【数据名】&#xff1a;【id】 可读性强&#xff0c;在客户端的情况下使用:如果前缀相同会分目录层级长度不超过44字节 string数据结构的三种类型&#xff0c;在44字节之内是embstring 内存…

1.5MHz,1.2A COT 架构同步降压变换器只要0.16元,型号:LN3435

推荐原因 1.5MHZ的开关频率&#xff0c;可以使用小电感&#xff0c;1.2A满足多数应用&#xff0c;价格感人&#xff0c;只要0.16元 产品概述 LN3435是一款电流模COT架构同步降压开关稳压器。 输入范围为 2.7V-6.0V&#xff0c;可提供 1.2A 的连续输出电流。 内部集成了低内阻…

【Excel2LaTeX】复杂表格制作的解决方案

刚开始用LaTeX写论文&#xff0c;遇到的第一道坎就是绘制表格&#xff0c;较小的普通表格可以通过简单的语法实现&#xff0c;但是较大的复杂的表格却让我无从下手。 Excel2LaTeX插件 这里介绍一种我用到非常顺手的工具&#xff1a;Excel2LaTeX插件&#xff0c;下载地址&#x…

SQL系统函数知识点梳理(Oracle)

这里写目录标题 函数系统函数转换函数to_date()to_char()将数值转换成字符格式 添加货币符号将日期转换成字符 其他不常用的转换函数 字符型函数连接函数大小写转换函数大写转换小写转换首字母大写&#xff0c;其余的小写 替换函数去除空格函数截取函数填充函数获取字符长度函数…

35、链表-LRU缓存

思路&#xff1a; 首先要了解LRU缓存的原理&#xff0c;首先定下容量&#xff0c;每次get请求和put请求都会把当前元素放最前/后面&#xff0c;如果超过容量那么头部/尾部元素就被移除&#xff0c;所以最近最少使用的元素会被优先移除&#xff0c;保证热点数据持续存在。 不管放…

宿州市水环境投资 | 邀您参加2024全国水科技大会暨技术装备成果展览会

嘉宾简介 田 云 宿州市水环境投资建设有限公司 董事长兼总经理 报告题目&#xff1a;宿州市主城区水环境智慧水务建设交流 男&#xff0c;回族&#xff0c;1976年6月生&#xff0c;新疆克拉玛依人&#xff0c;2007年4月加入中国共产党&#xff0c;1999年7月参加工作&a…

docker安装clickhouse数据库

1.创建目录 mkdir -p /data/clickhouse/data mkdir -p /data/clickhouse/conf mkdir -p /data/clickhouse/log2.拉取镜像 docker pull clickhouse/clickhouse-server3.创建临时容器 docker run -d --rm --name clickhouse-server --ulimit nofile262144:262144 clickhouse/c…

ELK日志分析系统之Kafka

目录 一、消息队列基本介绍 1、为什么需要消息队列(MQ) 2、使用消息队列的好处 1.解耦 2.可恢复性 3.缓冲 4.灵活性 & 峰值处理能力 5.异步通信 3、Kafka消息队列的两种模式 1.点对点模式 2.发布/订阅模式 二、Kafka基本介绍 1、Kafka定义 2、Kafka概念 3、…

IO流高级流

前言 缓冲区能够提升输入输出的效率 虽然FileReader和FileWriter中也有缓冲区 但是BufferedReader和BufferWriter有两个非常好用的方法. 缓冲流 字节缓冲流 import java.io.*;public class BufferedStreamDemo {public static void main(String[] args) throws IOExceptio…

网工基础协议——TCP/UDP协议

TCP和UDP的不同点&#xff1a; TCP(Transmission Control Protocol&#xff0c;传输控制协议)&#xff1b; UDP(User Data Protocol&#xff0c;用户数据报协议)&#xff1b; TCP&#xff1a;传输控制协议&#xff0c;面向连接可靠的协议&#xff0c;只能适用于单播通信&…

Remote Desktop Web修改密码,自动填写域前缀

C:\Windows\Web\RDWeb\Pages\zh-CN\password.aspx 内 添加 value“ITinfra” CMD或者powershell 重启IIS服务&#xff1b; iisreset

【漏洞复现】飞企互联-FE企业运营管理平台 ProxyServletUti接口处存在任意文件读取漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

设备全生命周期管理平台:各领域的关键手段

在当今的各个领域中&#xff0c;设备全生命周期管理平台正逐渐崭露头角&#xff0c;成为提高设备管理水平的关键手段。 数字化转型已成为众多企业的重要发展方向&#xff0c;将设备管理数字化可显著提高效率与准确性。同时&#xff0c;智能化应用&#xff0c;如利用人工智能和机…

Java——代码块

目录 一.代码块概念以及分类 二.普通代码块 三.构造代码块 四.静态代码块 一.代码块概念以及分类 使用 {} 定义的一段代码称为代码块。根据代码块定义的位置以及关键字&#xff0c;又可分为以下四种&#xff1a; 普通代码块构造块静态块同步代码块&#xff08;后续讲解多…

【vue3】插件@tsparticles/vue3、tsparticles实现粒子特效

文章目录 一、安装依赖二、全局引入三、使用 一、安装依赖 npm i tsparticles/vue3 npm i tsparticles二、全局引入 // main.js import Particles from tsparticles/vue3 import { loadFull } from tsparticlesconst app createApp(App) app.use(Particles, {init: async (e…

远程连接服务器ubuntu系统的PyCharm打不开

问题&#xff1a;远程连接服务器ubuntu系统&#xff0c;PyCharm打不开 尝试杀死服务器进程&#xff0c;重新连接服务器&#xff1a;pkill -u 用户名XShell远程连接&#xff0c;都打不开 解决方案&#xff1a;

python复制文件夹内容

参考博客 https://blog.csdn.net/itfans123/article/details/133710731 案例1 import os import shutildef copy_folder(source_folder, destination_folder):# 创建目标文件夹os.makedirs(destination_folder, exist_okTrue)# 遍历源文件夹中的所有文件和文件夹for item in …

刷穿力扣006-剑指offer一数组——02寻找目标值-二维数组

刷穿力扣006-剑指offer<一>数组——02寻找目标值-二维数组 基本面试题都是我带大家刷的力扣热题100和剑指offer的75道题&#xff0c;建议刷两遍&#xff01;&#xff08;ps:想找工作实习的同学&#xff0c;文末有面试八股和简历模板&#xff09; 题目&#xff1a; 语言…

Python爬虫入门教程!

什么是爬虫? 爬虫就是自动获取网页内容的程序&#xff0c;例如搜索引擎&#xff0c;Google&#xff0c;Baidu 等&#xff0c;每天都运行着庞大的爬虫系统&#xff0c;从全世界的网站中爬虫数据&#xff0c;供用户检索时使用。 爬虫流程 其实把网络爬虫抽象开来看&#xff0c;它…