达梦(DM) SQL聚集函数及日期运算操作

达梦DM SQL聚集函数及日期运算操作

  • 聚集函数
    • MAX、MIN、SUM、AVG、COUNT
    • 使用分析函数 sum (…) over (order by…) 可以生成累计和
    • 更改累计和的值
    • 计算出现次数最多的值
  • 日期运算
    • 加减日、月、年
    • 加减时、分、秒
    • 日期间隔之时、分、秒
    • 日期间隔之日、月、年
    • 求两个日期间的工作天数
    • 确定当前记录和下一条记录之间相差的天数

这里讲解DM数据库的操作,主要涉及聚集函数、分析函数、日期运算、日期操作等操作。

聚集函数

MAX、MIN、SUM、AVG、COUNT

SQL 中的聚集函数共包括 5 个 (MAX、MIN、SUM、AVG、COUNT),可以帮我们求某列的最大值、最小值及平均值等

-- 查询每个部门员工的平均薪资、最小薪资、最大薪资、总工资及总记录SELECT deptno,AVG (salary) AS 平均值,MIN (salary) AS 最小值,MAX (salary) AS 最大值,SUM (salary) AS 工资合计,COUNT (*) AS 总行数FROM employee GROUP BY deptno;

查询结果如图
在这里插入图片描述
当表中没有数据时,不加 group by 会返回一行数据,加了 group by 无数据返回,先建空表

CREATE TABLE employee2 AS SELECT * FROM employee WHERE 1 = 2;

不加 group by

SELECT COUNT (*) AS cnt, SUM (salary) AS sum_sal FROM employee2 WHERE deptno = 11;

执行结果如图
在这里插入图片描述
增加 group by

SELECT COUNT (*) AS cnt, SUM (salary) AS sum_sal FROM employee2 WHERE deptno = 11 group by deptno;

执行结果如图
在这里插入图片描述
清空表数据

truncate table TEST

使用分析函数 sum (…) over (order by…) 可以生成累计和

使用分析函数 sum (…) over (order by…) 可以生成累计和,查询部门1下的工资累计

-- 按员工编号排序对员工的工资进行累加SELECT empno AS 编号,ename AS 姓名,salary AS 人工成本,SUM (salary) OVER (ORDER BY empno) AS 成本累计FROM employeeWHERE deptno = 1;

执行结果如图
在这里插入图片描述
结果是当前部门下按照empno排序从第一行到当前行的所有工资之和,为了形象地说明这一点,我们用 listagg 模拟出每一行是哪些值相加

-- 使用 listagg 函数模拟员工总成本的累加值SELECT empno                                                AS 编号,ename                                              AS 姓名,salary                                                     AS 人工成本,SUM (salary) OVER (ORDER BY empno)                   AS 成本累计,(SELECT LISTAGG (salary, '+') WITHIN GROUP (ORDER BY empno)FROM employee bWHERE b.deptno = 1 AND b.empno <= a.empno)  计算公式FROM employee aWHERE deptno = 1ORDER BY empno;

执行结果如图
在这里插入图片描述

更改累计和的值

更改累计和的值,为了方便测试,创建视图

CREATE OR REPLACE VIEW v (id,amt,trx) ASSELECT 1,100,'PR' FROM dual UNION ALLSELECT 2,100,'PR' FROM dual UNION ALLSELECT 3,50,'PY' FROM dual UNION ALLSELECT 4,100,'PR' FROM dual UNION ALLSELECT 5,200,'PY' FROM dual UNION ALLSELECT 6,50,'PY' FROM dual;SELECT * FROM v;

创建完成后结果如图
在这里插入图片描述
• id 是唯一列。
• amt 列表示每次事务处理(存款或取款)涉及到的金额。
• trx 定义了事务的类型,取款是 PY,存款是 PR。
先要求计算每次存/取款后的余额,如果 trx 是 PR,则加上 amt 值代表的金额;否则减去 amt 值代表的金额。这实际上是一个累加问题,我们可以把取款的值先变成负数。

 SELECT id,CASE WHEN trx = 'PY' THEN '取款' ELSE '存款' END 存取类型,amt 金额,(CASE WHEN trx = 'PY' THEN -amt ELSE amt END) AS 余额FROM vORDER BY id;

在这里插入图片描述
累加处理后的结果

  SELECT id,CASE WHEN trx = 'PY' THEN '取款' ELSE '存款' END 存取类型,amt 金额,SUM (CASE WHEN trx = 'PY' THEN -amt ELSE amt END) OVER (ORDER BY id)AS 余额FROM vORDER BY id;

执行结果如图
在这里插入图片描述

计算出现次数最多的值

使用 partition by 子句查看部门中哪个工资等级的员工最多
1.计算不同工资出现的次数

SELECT salary, COUNT (*) AS 出现次数 FROM employee GROUP BY salary;

执行结果如图
在这里插入图片描述
2.按次数排序生成序号

SELECT salary,DENSE_RANK () OVER (ORDER BY 出现次数 DESC) AS 次数排序 FROM (  SELECT salary, COUNT (*) AS 出现次数 FROM employee GROUP BY salary);

执行结果如图
在这里插入图片描述
3.根据序号过滤得到需要的结果

SELECT salary FROM (SELECT salary, DENSE_RANK () OVER (ORDER BY 出现次数 DESC) AS 次数排序FROM (  SELECT salary, COUNT (*) AS 出现次数 FROM employee GROUP BY salary) x) yWHERE 次数排序 = 1;

执行结果如图
在这里插入图片描述
4.利用 partition by 子句查询各部门哪个工资等级的员工最多

SELECT deptno, salary FROM (SELECT deptno,salary,DENSE_RANK () OVER (PARTITION BY deptno ORDER BY 出现次数 DESC)AS 次数排序FROM (  SELECT salary, deptno, COUNT (*) AS 出现次数 FROM employee GROUP BY deptno, salary) x) yWHERE 次数排序 = 1; 

执行结果如图
在这里插入图片描述
部门 1 、 2 中各工资档次出现次数都为 1,所以返回所有的数据。

日期运算

加减日、月、年

date 类型的数据可以直接加减天数,加减月份需要使用 add_months 函数,同时也可以使用 add_days 加减天数

SELECT hiredate AS 聘用日期,add_days (hiredate, -5) AS5,add_days (hiredate, 5) AS5,add_months (hiredate, -5) AS5,add_months (hiredate, 5) AS5,add_months (hiredate, -5 * 12) AS5,add_months (hiredate, 5 * 12) AS5FROM employeeWHERE ROWNUM <= 1;

执行结果如图
在这里插入图片描述

加减时、分、秒

时间类型的数据可以直接加减时、分、秒,1/24 指的是 1 小时

select sysdate as 当前日期,sysdate - 5.0 / 24 as5小时,sysdate + 5.0 / 24 as5小时,sysdate - 5.0 / 24 / 60 as5分钟,sysdate + 5.0 / 24 / 60 as5分钟from dual;

执行结果如图
在这里插入图片描述

日期间隔之时、分、秒

两个 date 相减,得到的是天数,乘以 24 即为小时,以此类推可计算出秒。employee 表数据如下
在这里插入图片描述
计算日期间隔

SELECT 间隔天数,间隔天数 * 24 AS 间隔小时,间隔天数 * 24 * 60 AS 间隔分,间隔天数 * 24 * 60 * 60 AS 间隔秒FROM (SELECT MAX (hiredate) - MIN (hiredate) AS 间隔天数FROM employeeWHERE empno IN (1,2)) x;

执行结果如图
在这里插入图片描述

日期间隔之日、月、年

使用 months_between 函数计算间隔月份,以此类推计算出间隔年

SELECT max_hd - min_hd 间隔天,MONTHS_BETWEEN (max_hd, min_hd) 间隔月,MONTHS_BETWEEN (max_hd, min_hd) / 12 间隔年FROM (SELECT MAX (hiredate) max_hd, MIN (hiredate) min_hdFROM employee);

执行结果如图
在这里插入图片描述

求两个日期间的工作天数

查询原始数据

SELECT empno, hiredate FROM employee WHERE empno IN (1,2);          

执行结果如图
在这里插入图片描述
将原始数据转为一行

SELECT MIN (hiredate) AS min_hd, MAX (hiredate) AS max_hd FROM employee WHERE empno IN (1,2);  

在这里插入图片描述
枚举两个日期之间的天数

select (max_hd-min_hd)+1 as 天数 from (SELECT MIN (hiredate) AS min_hd, MAX (hiredate) AS max_hd FROM employee WHERE empno IN (1,2));          

在这里插入图片描述
创建中间表t500

CREATE TABLE t500 AS SELECT LEVEL AS ID FROM dual CONNECT BY LEVEL <= 500;

在这里插入图片描述
与 t500 做笛卡尔积枚举 30 天的所有日期

SELECT min_hd + (t500.id - 1) AS 日期FROM (SELECT MIN (hiredate) AS min_hd, MAX (hiredate) AS max_hd FROM employee WHERE empno IN (1,2)) x,t500WHERE t500.id <= ( (max_hd - min_hd) + 1);  

在这里插入图片描述
根据日期得到对应的工作日信息

SELECT 日期, TO_CHAR (日期, 'DY', 'NLS_DATE_LANGUAGE = American') AS dy FROM (SELECT min_hd + (t500.id - 1) AS 日期FROM (SELECT MIN (hiredate) AS min_hd, MAX (hiredate) AS max_hd FROM employee WHERE empno IN (1,2)) x,t500WHERE t500.id <= ( (max_hd - min_hd) + 1)); 

在这里插入图片描述
过滤工作日数据汇总

SELECT COUNT(*) FROM (SELECT 日期, TO_CHAR (日期, 'DY', 'NLS_DATE_LANGUAGE = American') AS dy FROM (SELECT min_hd + (t500.id - 1) AS 日期FROM (SELECT MIN (hiredate) AS min_hd, MAX (hiredate) AS max_hd FROM employee WHERE empno IN (1,2)) x,t500WHERE t500.id <= ( (max_hd - min_hd) + 1))) WHERE dy NOT IN ('SAT','SUN');  

在这里插入图片描述
得到10个工作日。
求一年中周内各日期的天数
可以按照以下步骤分析
• 取得大当前年度信息。
• 计算一年有多少天。
• 生成日期列表。
• 转换为对应的星期标识。
• 汇总统计。

WITH x0 AS (SELECT TO_DATE ('2023-01-01', 'yyyy-mm-dd') AS 年初 FROM DUAL),x1 AS (SELECT 年初, ADD_MONTHS (年初, 12) AS 下年初 FROM x0),x2 AS (SELECT 年初, 下年初, 下年初 - 年初 AS 天数 FROM x1),x3 AS (SELECT 年初 + (LEVEL - 1) AS 日期 FROM x2 CONNECT BY LEVEL <= 天数),x4 AS (SELECT 日期, TO_CHAR (日期, 'DY') AS 星期 FROM x3)SELECT 星期, COUNT (*) AS 天数 FROM x4 GROUP BY 星期;   

在这里插入图片描述

确定当前记录和下一条记录之间相差的天数

使用 lead() over() 分析函数

SELECT empno,ename,hiredate,LEAD (hiredate) OVER (ORDER BY hiredate) next_hd FROM employee;

在这里插入图片描述
计算日期差值

SELECT empno,ename,hiredate,next_hd,next_hd-hiredate diff FROM (SELECT empno,ename,hiredate,LEAD (hiredate) OVER (ORDER BY hiredate) next_hd FROM employee);

在这里插入图片描述
到这里,关于DM数据库的聚集函数及日期运算操作也就算说完了,后续继续进行其他场景操作。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Microsoft Access Database使用

“小规模数据用Excel&#xff0c;大规模数据用Access。” 当涉及到大规模数据时&#xff0c;使用excel非常的卡顿&#xff0c;使用access就不会出现这个问题。 一、常用操作 1.新建一个数据库 直接右键&#xff0c;新建 access数据库 2.excel内容导入到access中&#xff08;成…

阿里云服务器(Ubuntu22)上的MySQL8更改为大小写不敏感

因为windows上默认的mysql8.0是大小写不敏感的&#xff0c;部署到服务器上之后发现ubuntu默认的是大小写敏感&#xff0c;所以为了不更改代码&#xff0c;需要将mysql数据库设置为大小写不敏感的。 &#xff01;&#xff01;&#xff01;重要一定要做好数据库的备份&#xff0…

零基础HTML教程(31)--HTML5多媒体

文章目录 1. 背景2. audio音频3. video视频4. audio与video常用属性5. 小结 1. 背景 在H5之前&#xff0c;我们要在网页上播放音频、视频&#xff0c;需要借助第三方插件。 这些插件里面最火的就是Flash了&#xff0c;使用它有几个问题&#xff1a; 首先要单独安装Flash&…

机器学习:逻辑回归

概念 首先&#xff0c;逻辑回归属于分类算法&#xff0c;是线性分类器。我们可以认为逻辑回归是在多元线性回归的基础上把结果给映射到0-1的区间内&#xff0c;hθ&#xff08;x&#xff09;越接近1越有可能是正例&#xff0c;反之&#xff0c;越接近0越有可能是负例。那么&am…

前端如何将接口传来的列表数据(数组)直接下载成csv文件

前言&#xff1a;最近遇到一个需求&#xff0c;需要实现一个下载表格数据的操作&#xff0c;一般来说是前端请求后端的下载接口&#xff0c;将文件流下载下来&#xff0c;但是因为这个项目任务时间比较紧&#xff0c;后端没时间做下载接口&#xff0c;所以暂时由前端直接调列表…

JAVA基础---Stream流

Stream流出现背景 背景 在Java8之前&#xff0c;通常用 fori、for each 或者 Iterator 迭代来重排序合并数据&#xff0c;或者通过重新定义 Collections.sorts的 Comparator 方法来实现&#xff0c;这两种方式对 大数量系统来说&#xff0c;效率不理想。 Java8 中添加了一个…

张大哥笔记:服务器有挖矿木马程序,该如何处理?

这篇文章发表于2021年&#xff0c;今天借这个平台再发布一下&#xff0c;希望对大家有所帮助&#xff01; 今天收到一个粉丝求助&#xff0c;说收到了阿里云官方短信通知提示有挖矿程序&#xff0c;要求立即整改&#xff0c;否则会关停服务器&#xff0c;以下是我和他的对话内…

代码学习录打卡Day13

1 滑动窗口最大值 使用单调队列&#xff0c;需要一个队列&#xff0c;这个队列呢&#xff0c;放进去窗口里的元素&#xff0c;然后随着窗口的移动&#xff0c;队列也一进一出&#xff0c;每次移动之后&#xff0c;队列告诉我们里面的最大值是什么。 class MyQueue { public:vo…

WebSocket 全面解析

&#x1f31f; 引言 WebSocket&#xff0c;一个让实时通信变得轻而易举的神器&#xff0c;它打破了传统HTTP协议的限制&#xff0c;实现了浏览器与服务器间的全双工通信。想象一下&#xff0c;即时消息、在线游戏、实时股票报价…这一切都离不开WebSocket的魔力&#x1f4ab;。…

Python量化炒股的获取数据函数—get_concept()

查询股票所属的概念板块函数get_concept()&#xff0c;利用该函数可以查询一只或多只股票所属的概念板块&#xff0c;其语法格式如下&#xff1a; get_concept(security, dateNone)security&#xff1a;标的代码。类型为字符串&#xff0c;形式如‘000001.XSHE’&#xff0c;或…

宽字符的来历:从ASCII到Unicode,C语言中的宽字符处理

目录 一、ASCII编码&#xff1a;字符世界的开篇 二、Unicode与宽字符的诞生 宽字符类型与宽字符串 三、C语言中的宽字符处理函数 四、宽字符与多字节字符 结语 在计算机科学的发展历程中&#xff0c;字符编码经历了从简单到复杂、从单一语言到全球多语种支持的演变过程。…

【论文阅读】IPT:Pre-TrainedImageProcessingTransformer

Pre-TrainedImageProcessingTransformer 论文地址摘要1. 简介2.相关作品2.1。图像处理2.2。 Transformer 3. 图像处理3.1. IPT 架构3.2 在 ImageNet 上进行预训练 4. 实验4.1. 超分辨率4.2. Denoising 5. 结论与讨论 论文地址 1、论文地址 2、源码 摘要 随着现代硬件的计算能…

2024年第十五届蓝桥杯江苏省赛回顾

呜呜呜~~~ 我在考完了后感觉自己直接炸了&#xff1a;好多学到的算法都没有用上&#xff0c;几乎所有的题目都是暴力的。。。 最后十几分钟对于一道dp算法终于有思路了&#xff0c;但是。。匆匆忙忙之间就是没有调试出来。&#xff08;还是交了一道暴力[旋风狗头]直接哭死~~&…

iOS - 多线程-atomic

文章目录 iOS - 多线程-atomic1. 源码分析1.1 get方法1.2 set方法 2. 一般不使用atomic的原因 iOS - 多线程-atomic atomic用于保证属性setter、getter的原子性操作&#xff0c;相当于在getter和setter内部加了线程同步的锁可以参考源码objc4的objc-accessors.mm它并不能保证使…

Whisper、Voice Engine推出后,训练语音大模型的高质量数据去哪里找?

近期&#xff0c;OpenAI 在语音领域又带给我们惊喜&#xff0c;通过文本输入以及一段 15 秒的音频示例&#xff0c;可以生成既自然又与原声极为接近的语音。值得注意的是&#xff0c;即使是小模型&#xff0c;只需一个 15 秒的样本&#xff0c;也能创造出富有情感且逼真的声音。…

springboot3常用注解使用

组键注册注解 组件注册步骤总结 条件注解 演示示例 属性绑定注解 ConfigurationProperties进行绑定 EnableConfigurationProperties进行绑定 其他常用注解 EnableAutoConfiguration ComponentScan RequestMapping GetMapping PostMapping Autowired Resource Servi…

Objective-C大爆炸:从零到单例模式

oc学习笔记&#xff08;一&#xff09; 文章目录 oc学习笔记&#xff08;一&#xff09;oc与c语言的区别#import的用法foundation框架NSLog函数NSString类型符号的作用oc中的数据类型 类与对象概念&#xff1a; 创建第一个类类的定义类的实现类加载对象的产生和使用 self语法id…

为什么说B端SaaS产品经理需要让研发团队懂业务

先问是不是&#xff0c;再问为什么。这个问题即对也不对。 1.对的地方&#xff1a;研发团队里面的架构师、前后端leader、组长或者骨干如果懂业务的话&#xff0c;就能在做系统业务架构、信息架构和数据架构的时候多一些前瞻性&#xff0c;为后期业务扩展预留一些接口或者能力…

ElasticSearch面试题2

Mapping属性详细介绍/常见的字段数据类型&#xff1a; 映射(mapping)︰mapping是对索引库中文档的约束信息&#xff08;例如字段名、数据类型&#xff09;&#xff0c;类似表的结构约束&#xff1b;每个索引库都应该有自己的映射 数据库一定要先创建表才能去添加数据…

【机器学习】视觉基础模型的三维意识:前沿探索与局限

视觉基础模型的三维意识&#xff1a;前沿探索与局限 一、引言二、视觉基础模型的三维意识三、当前模型的局限性四、实验与结果五、总结与展望 大规模预训练的进展已经产生了具有强大能力的视觉基础模型。最近的模型不仅可以推广到任意图像的训练任务&#xff0c;而且它们的中间…