Oracle基础知识(二)
目录
1.聚合函数
2.COUNT(1)&COUNT(*)&COUNT(字段)区别(面试常问)
3.分组聚合——group by
4.去重:DISTINCT 、GROUP BY
5.聚合函数的过滤HAVING
6.oracle中having与where的区别 (面试常问)
7.ROUND与TRUNC函数
8.ROLLUP上卷与CUBE各维度汇总
9.子查询
单行子查询案例:
多行子查询案例:
1.聚合函数
聚合函数:可以同时对多行进行操作,并返回一个结果
聚合函数有:
(1)avg(x):返回x的平均值;
(2)count(x):查询返回的行数;
(3)max(x):返回x的最大值;
(4)min(x):返回x的最小值;
(5)median(x):返回x的中位数;
(6)sum(x):返回x的和;
2.COUNT(1)&COUNT(*)&COUNT(字段)区别(面试常问)
COUNT(1)&COUNT(*) 都是统计行数 得到的结果都是一样的
但是 COUNT(1) 比 COUNT(*) 性能要好一点,因为COUNT(*)需要先得到表的字段信息然后再计数。
而COUNT(1)相当于新增一列,然后对该列进行直接计数。
COUNT(字段)是统计该字段非空的行数(不把为空的行统计进去)
3.分组聚合——group by
分组的情况下,group by后面有什么字段,select 才可以查对应的字段
4.去重:DISTINCT 、GROUP BY
特性 | DISTINCT | GROUP BY |
---|---|---|
主要用途 | 去除查询结果中的重复行 | 对数据进行分组并允许使用聚合函数 |
是否可与聚合函数一起使用 | 不可以 | 可以 |
对输出的影响 | 返回去重后的结果集 | 根据分组条件返回每组的汇总信息 |
性能考虑 | 对于简单去重操作较为直接有效 | 更适合需要汇总、统计等复杂查询 |
示例 | SELECT DISTINCT department_id FROM employees; | SELECT department_id, COUNT(*) FROM employees GROUP BY department_id; |
5.聚合函数的过滤HAVING
HAVING必须和group by 配合使用,且having必须在group by后面
HAVING 关键字和 WHERE 关键字都可以用来过滤数据,
且 HAVING 支持 WHERE 关键字中所有的操作符和语法。
注意:使用聚合函数之前尽量先用where进行过滤,先过滤再分组
避免查*,用到哪些字段就查询哪些字段
6.oracle中having与where的区别 (面试常问)
- where 不能放在 group by 的后面
- HAVING 是跟 GROUP BY 连在一起用的,放在 GROUP BY 后面,此时的作用相当于WHERE
- WHERE 后面的条件中不能有聚合函数,比如 SUM()、AVG()等,而 HAVING 可以
示例1:找出部门平均薪资大于1000 并且 部门编号不为10的 部门和部门平均薪资
select deptno,avg(sal) avg_sal
from emp
where deptno<>10
group by deptno
having avg(sal)>1000;
7.ROUND与TRUNC函数
ROUND(x,y)--四舍五入至y位小数
ROUND(x)--四舍五入至整数
TRUNC(x,y)--根据指定的小数位数截断数值(不进行四舍五入)。
8.ROLLUP上卷与CUBE各维度汇总
特性 | ROLLUP(job, deptno) | CUBE(job, deptno) |
---|---|---|
汇总层级 | 层次化汇总 | 所有可能组合 |
包含哪些分组 | (job, deptno), (job), () | (job, deptno), (job), (deptno), () |
是否包含部门小计 | ❌ 不包含只按部门的小计 | ✅ 包含 |
结果行数 | 较少 | 更多 |
9.子查询
--单行子查询,返回的结果里只有一条数据 SELECT COUNT(1) FROM EMP;
--多行子查询,返回的结果集里有多条数据 SELECT ENAME FROM EMP;
单行子查询案例:
示例:查询EMP,找出哪些人薪资比SCOTT用户高
SELECT SAL
FROM EMP
WHERE ENAME = 'SCOTT';
--
SELECT ENAME
FROM EMP
WHERE SAL > 3000;
--
SELECT ENAME
FROM EMP
WHERE SAL > (SELECT SALFROM EMPWHERE ENAME = 'SCOTT');
多行子查询案例:
示例:在10 和 20 部门中找出工作岗位和30部门中存在的任意一个岗位相同的员工的信息
SELECT DISTINCT JOB
FROM EMP
WHERE DEPTNO = 30;SELECT *
FROM EMP
WHERE DEPTNO IN (10, 20)AND JOB IN (SELECT DISTINCT JOBFROM EMPWHERE DEPTNO = 30);
相关文章:
Oracle基础知识(二)
目录 1.聚合函数 2.COUNT(1)&COUNT(*)&COUNT(字段)区别(面试常问) 3.分组聚合——group by 4.去重:DISTINCT 、GROUP BY 5.聚合函数的过滤HAVING 6.oracle中having与where的区别 (面试常问) 7.ROUND与TRUNC函数 8.ROLLUP上卷…...
轻量化MEC终端 特点
MEC(多接入边缘计算)解决方案通过将计算能力下沉至网络边缘,结合5G网络特性,已在多个行业实现低延迟、高可靠、高安全的应用部署。以下从技术架构、核心优势及典型场景三方面进行总结: 一、技术架构 分层设计 MEC架…...
Git 提交大文件 this exceeds GitHub‘s file size limit of 100.00 MB
报错核心: File …/encoder-epoch-99-avg-1.int8.onnx is 173.47 MB File …/encoder-epoch-99-avg-1.onnx is 314.79 MB this exceeds GitHub’s file size limit of 100.00 MB 正确做法:使用 Git LFS 上传大文件 GitHub 对 单个文件最大限制是 100MB&…...
前后端的双精度浮点数精度不一致问题解决方案,自定义Spring的消息转换器处理JSON转换
在 Java 中,Long 是一个 64 位的长整型,通常用于表示很大的整数。在后端,Long 类型的数据没有问题,因为 Java 本身使用的是 64 位的整数,可以表示的范围非常大。 但是,在前端 JavaScript 中,Lo…...
C语言—Linux环境下CMake设置库(动态/静态)
1. Yesterday Once More 由于昨日我们在VSCode设置了如何使用CMake构建与编译c语言项目,如有疑问,请看以下链接,今日根据昨天的配置来进一步完成项目的构建。 c语言- 如何构建CMake项目(Linux/VSCode)-CSDN博客 2. 动态…...
C语言---内存函数
memcpy函数的使用及模拟实现 memcpy的功能和strcpy类似,都是用来拷贝数据的。与strcpy不同的是,memcpy的适用性更广并且是以字节为单位来拷贝的。 void * memcpy ( void * destination, const void * source, size_t num ) memcpy函数的作用就是拷贝从so…...
vue项目启动报错(node版本与Webpack)
一、问题 因为项目需要将node版本从v14.17.0升级到v20.9.1了,然后启动项目报错 报错有些多,直接省略部分 building 2/2 modules 0 activeError: error:0308010C:digital envelope routines::unsupported at new Hash (node:internal/crypto/hash:79:19) …...
Vite + Vue 工程中,为什么需要关注 `postcss.config.ts`?
📜 前言:当传统 CSS 遇见现代工程 在 Vue 项目开发中,CSS 管理一直是一个容易被忽视但极其重要的环节。传统的 CSS 编写方式(如手动处理浏览器兼容性、全局样式污染)已无法适应现代前端工程的需求。而 PostCSS 作为 C…...
LeetCode热题100:Java哈希表中等难度题目精解
49. 字母异位词分组 题目描述 给定一个字符串数组,要求将字母异位词组合在一起。可以按任意顺序返回结果列表。 字母异位词是由重新排列源单词的所有字母得到的一个新单词。 示例 示例 1: 输入: strs ["eat", "tea", "tan", &…...
设计模式1 ——单例模式
定义 在 C 里,单例模式是一种常用的设计模式,其目的是保证一个类仅存在一个实例,并且为该实例提供一个全局访问点。 实现 1 饿汉式 class Singleton { private:static Singleton instance;Singleton() default;~Singleton() default;Si…...
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(26):のは ・ のが ・ のを
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(26):のは ・ のが ・ のを 1、前言(1)情况说明(2)工程师的信仰2、知识点(1)復習:(2)のは ・ のが ・ のを3、单词(1)日语(2)日语片假名单词4、相近词练习5、单词辨析记录6、总结1、前言 (1)情况说明…...
第18天-NumPy + Pandas + Matplotlib多维度直方图
示例1:带样式的柱状图 python 复制 下载 import numpy as np import pandas as pd import matplotlib.pyplot as plt# 生成数据 df = pd.DataFrame(np.random.randint(10, 100, size=(8, 4)),columns=[Spring, Summer, Autumn, Winter],index=[2015, 2016, 2017, 2018, 20…...
Qt初识.
认识 QLabel 类,能够在界面上显示字符串. 通过 setText 来设置的。参数 QString (Qt 中把 C 里的很多容器类,进行了重新封装。历史原因) 内存泄露 / 文件资源泄露对象树. Qt 中通过对象树,来统一的释放界面的控件对象. Qt 还是推荐使用 new 的…...
linux系统查看硬盘序列号
Linux系统查看硬盘信息指南 方法一:hdparm工具 sudo hdparm -i /dev/sda输出示例:在返回信息中查找"SerialNo"字段为序列号,"Model"字段为硬盘型号注意:必须使用root权限,普通用户需在命令前加s…...
用户栈的高效解析逻辑
一、背景 在之前的博客 内核逻辑里抓取用户栈的几种方法-CSDN博客 里,介绍了使用内核逻辑进行用户栈的函数地址的抓取逻辑,但是并没有涉及如何解析出函数符号的逻辑。 就如perf工具一样,它也是分为两个步骤,一个步骤是内核态抓取…...
【713. 乘积小于 K 的子数组】
Leetcode算法练习 笔记记录 713. 乘积小于 K 的子数组 713. 乘积小于 K 的子数组 此题和 209题什么区别,没有什么区别,关键时理解滑动窗口的作用。 public int numSubarrayProductLessThanK(int[] nums, int k) {if (k < 1){return 0;}int left 0;in…...
springboot 1.x2.x依赖spring版本
springboot 1.x&2.x依赖spring版本 Spring Boot 1.x 系列版本主要依赖于 Spring Framework 4.x。具体对应关系如下: Spring Boot 1.0.x → Spring Framework 4.0.xSpring Boot 1.1.x → Spring Framework 4.0.xSpring Boot 1.2.x → Spring Framework 4.1.xSp…...
TYUT-企业级开发教程-第9章
考点不多,不会考大题 异步任务 异步任务通常用于耗时较长或者不需要立即得到执行结果的业务,在 Spring 中,可以使用 Async 注解实现异步任务,被Async 注解标注的方法称之为异步方法,异步方法将在执行的时候ÿ…...
独占内存访问指令LDXR/STXR
一、原子操作的介绍 在计算机领域里,如果要在多线程的情况下要保持数据的同步,需要引入称作Load-Link(LL)和Store-Conditional(SC)的操作,通常简称为LL/SC。 LL操作返回一个内存地址上当前存储…...
FlashAttention:传统自注意力( Self-Attention)优化加速实现
摘要 FlashAttention 是一套专为 GPU 优化的精确自注意力(Self-Attention)实现,通过“输入/输出感知”(IO-awareness)和块化(Tiling)策略,利用片上 SRAM 缓存大幅降低对高带宽显存&…...
DSP定时器的计算
以下是 0 到 F 的十六进制数对应的四位二进制表示的对照表: 十六进制二进制00000100012001030011401005010160110701118100091001A1010B1011C1100D1101E1110F1111 定时器周期: 我们先将 0x1742 转换成二进制形式: 0x1742 0001 0111 0100 …...
2025.05.21华为暑期实习机考真题解析第二题
📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 02. 灾区物资调度路径规划 问题描述 在一次严重的自然灾害后,LYA负责协调救援物资的配送工作。救援区域包含多个受灾乡镇和一个物资集结点,各个地点之间的道路状况各异,有些甚至…...
ATT Global赞助非小号全球行,引领RWA创新浪潮
领先的Web3广告生态系统构建者Advertising Time Trace (ATT Global) 今日宣布,将作为特别赞助商,鼎力支持即将于2025年5月26日在吉隆坡盛大举行的非小号全球行之“You Deserve to be Loved” WALL X特别慈善活动。此次盛会由知名Web3平台非小号与WALL X、…...
在 stm32 中 volatile unsigned signed 分别有什么作用,分别在什么场景下使用?
在STM32开发中, plaintext 复制 volatile 、 plaintext 复制 unsigned 和 plaintext 复制 signed 是三个关键的关键字,它们的用途和场景如下: 1. plaintext 复制 volatile 关键字 作用: 禁止编译器优化ÿ…...
Pandoc3.7新特性:存在合并单元格的 HTML 表格会被保留为嵌入的 HTML 表格
问题描述 在 Pandoc 3.6 中,当将包含合并单元格的 HTML 表格 (<table>) 转换为 Markdown 格式时,表格会被直接转换为 Markdown 表格格式。然而,在 Pandoc 3.7 中,同样的操作结果发生了变化:合并单元格的 HTML 表…...
WPS深度适配鸿蒙电脑折叠形态,国产替代下的未来何在?
首先,从产业升级与国产替代的角度来看,这是中国信息技术产业由“可用”向“好用”跃迁的重要信号。长期以来,中国的办公软件市场高度依赖微软Office等国外产品,操作系统也主要被Windows、macOS等垄断。而随着鸿蒙系统的成熟以及WP…...
[java]数组
数组 Scanner innew Scanner(System.in); int[] numbersnew int[100]; int x; int cnt0; xin.nextInt(); while(x!-1){numbers[cnt]x;sumx;xin.nextInt(); } if(cnt>0){System.out.println(sum/cnt); }所有的元素具有相同的数据类型创建后不能改变大小 定义数组 元素个数…...
torch.matmul() VS torch.einsum()
torch.matmul():标准的矩阵乘法 向量-向量(点积) a torch.randn(3) # [3] b torch.randn(3) # [3] c torch.matmul(a, b) # 点积,标量输出矩阵-向量 A torch.randn(3, 4) # [3, 4] x torch.randn(4) # [4] y torch.matmul(A, x…...
leetcode 92. Reverse Linked List II
题目描述 92. Reverse Linked List II 是第206题的进阶版206. Reverse Linked List 思路很简单,但一次性通过还是有点难度的。 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(n…...
VUE3使用provice、inject实现组件间的方法调用
问题:A组件》B组件》C组件 C可以调用A的方法吗? A组件:提供一个refreshTable方法 provide(refreshTable,(e:params)>{ ElMessage(底层组件请求刷新表格e.staff_ide.shijian) params e renderTableData() }) C组件: 注入refres…...
WebSocket 是什么?
好记忆不如烂笔头,能记下点东西,就记下点,有时间拿出来看看,也会发觉不一样的感受. WebSocket 是一种基于 TCP 协议的全双工通信协议,用于在客户端(如浏览器)和服务器之间建立持久化的双向实时…...
Java虚拟机栈
有不少Java开发人员一提到Java内存结构,就会将JVM中的内存区理解为仅有Java堆(heap)和Java栈(stack)。这种划分想法来源于传统的C、C程序的内存布局结构,但是在Java里有些粗糙了。尽管这种理解和划分非常不全面,但是从某种意义上来说…...
内存屏障指令
一、理解内存屏障(Memory Barrier) 开发者显然不明白一个事实——程序实际运行时很可能并不完全按照开发者编写的顺序访问内存,因为现代计算机为了提高性能而采取乱序执行,内存乱序访问主要发生在如下两个阶段: 编译…...
【MC】红石比较器
在《我的世界》(Minecraft)中,红石比较器(Redstone Comparator) 是一种高级红石元件,主要用于 检测、比较或处理信号强度,同时还能与容器、特定方块互动。 红石比较器有两种模式: 比…...
鸿蒙进阶——驱动框架UHDF 机制核心源码解读(一)
文章大纲 引言一、uhdf 概述二、uhdf 的核心参与角色1、drivers/hdf_core/adapter/uhdf2/manager/device_manager.c1.1、drivers/hdf_core/framework/core/manager/src/devmgr_service.c#DevmgrServiceGetInstance通过objectId获取IDevmgrService实例1.2、drivers/hdf_core/fra…...
【C/C++】探索单例模式:线程安全与性能优化
文章目录 Singleton1 指针版本Version 1 非线程安全版本Version 2 加锁版本Version 3.1 双重检查锁版本 AtomicMutexVersion 3.2 双重检查锁版本 Atomic-onlyVersion 3 两种方式对比 2 引用版本Version 1 简单版本 不推荐Version 2 初始化安全版本Version 3 初始化操作安全版本…...
Windows安装MongoDb.并使用.NET 9连接
以下是在 Windows 系统上安装 MongoDB 的详细步骤: 方法一:通过安装向导 下载安装包 访问官网下载页:https://www.mongodb.com/try/download/community选择版本: Version:推荐最新稳定版(如 8.09࿰…...
React深度解析:Hooks体系与Redux Toolkit现代状态管理实践
前言 React作为当今最流行的前端框架之一,其生态体系不断演进,为开发者提供了更高效、更优雅的解决方案。本文将深入探讨React的两大核心主题:Hooks体系(特别是useState和useEffect)以及Redux Toolkit现代状态管理方案…...
【Linux安装与维护】
文章目录 一、实验目的二、实验环境三、实验内容3.1 Red Hat系统安装3.2 硬盘分区与挂载3.3 root密码恢复 四、总结4.1 问题与解决4.2 实验收获 一、实验目的 熟练掌握Red Hat Enterprise Linux 8.x/9.0系统的安装流程,包括虚拟机配置、自定义分区和软件选择。学会…...
具有思考模式模型部署:Qwen3、DeepSeek-R1-Distill、Phi-4、QWQ系列
文章目录 1 介绍 Qwen3、DeepSeek-R1-Distill、Phi-4、QWQ2 部署 Qwen3、DeepSeek-R1-Distill、Phi-4、QWQ3 模型运行 Qwen3、DeepSeek-R1-Distill、Phi-4、QWQ4 结果Qwen3-0.6BDeepSeek-R1-Distill-Qwen-1.5BPhi-4-mini-reasoning 平台采用Autodl:https://www.auto…...
Mac安装redis
1、 去往网址 http://编download.编redis.io/releases/ 找到任意 结尾为* .tar.gz的文件下载下来 2、使用终端进入下载下来的redis文件 3、直接执行redis-server 如果出现redis标志性的图代表成功 如果显示command not found :redis-server 则在终端再进入src文件夹下&…...
python-leetcode 71.每日温度
题目: 给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。 可以理…...
[250521] DBeaver 25.0.5 发布:SQL 编辑器、导航器全面升级,新增 Kingbase 支持!
目录 DBeaver 25.0.5 发布:SQL 编辑器、导航器全面升级,新增 Kingbase 支持! DBeaver 25.0.5 发布:SQL 编辑器、导航器全面升级,新增 Kingbase 支持! 近日,DBeaver 发布了 25.0.5 版本…...
Java枚举详解
文章目录 1. 引言1.1 什么是枚举1.2 为什么需要枚举1.3 枚举的优势 2. 枚举基础2.1 枚举的声明与使用基本声明在类中定义枚举枚举的基本使用 2.2 枚举的常用方法1. values()2. valueOf(String name)3. name()4. ordinal()5. toString()6. compareTo(E o)7. equals(Object other…...
Android13 wifi设置国家码详解
Android13 wifi设置国家码详解 文章目录 Android13 wifi设置国家码详解一、前言二、设置wifi国家码相关代码1、adb或者串口也能设置和获取当前国家码(1)查询命令的方式(2)获取和设置国家码的示例 2、Java代码设置国家码3、获取当前…...
Docker安装MinIO对象存储中间件
MinIO 是一个高性能、分布式的对象存储系统,兼容 Amazon S3 云存储服务协议,广泛应用于企业存储、大数据、机器学习和容器化应用等领域。以下是详细介绍: 核心特点 兼容 S3 API :全面兼容 Amazon S3 API,这意味着使用…...
EasyPan 使用及功能优化
文章目录 在线体验为什么我想做这个?kiftd网盘EasyPan EasyPan 客制化,升级为 RokiPan登录界面主界面分享 上传&下载速度测试下载上传 个人优化(部分截图):已实现功能汇总(原版 优化 )待实…...
word通配符表
目录 一、word查找栏代码&通配符一览表二、word替换栏代码&通配符一览表三、参考文献 一、word查找栏代码&通配符一览表 序号清除使用通配符复选框勾选使用通配符复选框特殊字符代码特殊字符代码or通配符1任意单个字符^?一个任意字符?2任意数字^#任意数字&#…...
word格式相关问题
页眉 1 去除页眉横线: 双击打开页眉,然后点击正文样式,横线就没有了。 2 让两部分内容的页眉不一样: 使用“分节符”区分两部分内容,分节符可以在“布局-分隔符”找到。然后双击打开页眉,取消“链接到前一…...
springboot使用xdoc-report包导出word
背景:项目需要使用xdoc-report.jar根据设置好的word模版,自动填入数据 导出word 框架使用 我的需求是我做一个模板然后往里面填充内容就导出我想要的word文件,问了下chatgpt还有百度,最后选用了xdocreport这个框架,主…...