百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

常用SQL系列之(八):列值累计、占比、平均值以及日期运算等

csdh11 2024-12-17 12:12 47 浏览

本系统为@牛旦教育IT课堂在微头条上发布的内容,

为便于查阅,特辑录于此,都是常用SQL基本用法。

前两篇连接:

(一):SQL点滴(查询篇):数据库基础查询案例实战

(二):SQL点滴(排序篇):数据常规排序查询实战示例

(三):常用SQL系列之:记录叠加、匹配、外连接及笛卡尔等

(四):常用SQL系列之:Null值、插入方式、默认值及复制等

(五):常用SQL系列之:多表和禁止插入、批量与特殊更新等

(六):常用SQL系列之:删除方式、数据库、表及索引元信息查询等

(七):常用SQL系列之:表约束、最大/小值、非null数、平均值等



SQL点滴(46):如何通过SQL语句计算某个列值的累计和?


比如在员工信息表中有工资列,假设有3列,员工ABC三人,工资分别为400,600,900,那么希望通过sql语句,多出一列值,分别显示的内容就是列值的累计,分别为400,1000,1900.如何实现呢?
参考语句可以类似这样来写(mySQL为例,PostgreSQL和SQL Server也适用):
SELECT
e.ename,
e.salary,
( SELECT sum( d.salary ) FROM employee d WHERE d.emid <= e.emid ) AS sumtotal
FROM
employee e
ORDER BY 3
----------------------------
若是在Oracle中实现此功能,语句会更简单些(也适用DB2),参考示例如下:
select ename,salary,sum(salary) over (order by salary,emid) as sumtotal from employee order by 2.
通过SQL语句来实现这样的功能,比单纯的用程序读取数据在处理是不是更爽啊。试试吧。

SQL点滴(47):如何计算计算指定列中某类值占总合的百分比?



比如,员工工资表中员工分属不同部门,不如部门3有员工,工资分别为300,500,而员工工资列的总和(所有员工)为8000,这样可以算出部门3的工资占总工资的10%,那如何通过SQL实现呢?
1)、这里以MySQL未来,实例如下所示:
SELECT
d3,total, ROUND( ( d3 / total ) * 100, 2 ) AS pct
FROM
( SELECT sum( CASE WHEN departid = 3 THEN salary END ) AS d3, sum( salary ) AS total FROM employee ) emp
这个也适用PostgreSQL数据库。
2)、其它的数据库比如OracleDB2和MSSQL,可以参照如下SQL实现:
select distinct(d3/total)*100 as pct
from (select departid,sum(salary) over () total,sum(salary) over(partition by departid) 10
from employee) x
where departid =3
OK,一则分享就这些了,试试吧。

SQL点滴(48):“去掉一个最高分,去掉一个最低分”,如何计算平均分?


看综艺的节目的经常有专家组评分,常常是把最高和最低的排除,计算其余数的平均分这种情况。用数据库的表述就是“计算不包含最大值和最小值其余列值总和平均值”,我们来看如何用SQL实现,比如计算剔除员工最高薪和最低薪来计算平均工资,参考SQL语句:
1)MySQL写法——
SELECT
count( salary ),
avg( salary )
FROM
employee
WHERE
salary NOT IN ( ( SELECT min( salary ) FROM employee ), ( SELECT max( salary ) FROM employee ) )
这个写法也是适用PostgreSQL的。注意count只是为确认计算了多少个列值。可省去。
这里需要注意的是:如果存在重复值(最大最小值),那么都会排除在平均值外。
2)Oracle写法:
SELECT
avg( salary )
FROM (
select salary,min(salary) over() min_sal,max(salary) over() max_sal from employee
) x
WHERE
salary NOT IN (min_sal,max_sal )
这个写法,同样适合DB2和MS SQL。
问题,如果他们也有重复值,这种计算会怎样?自己动手试试吧。

SQL点滴(49):如何用SQL实现年月日的加减运算?



经常在程序中要处理日期,若利用数据库提供的日期处理功能,可以大大提高处理效率。那么数据库中如何通过SQL来操作日期呢?参考如下:
1)MySQL的日期加减法(对当前日期的年月日的加减)运算SQL:
SELECT
now( ) AS curdate,
now( ) - INTERVAL 5 DAY AS cd_minus_5D,
now( ) + INTERVAL 5 DAY AS cd_plus_5D,
now( ) - INTERVAL 5 MONTH AS cm_minus_5M,
now( ) + INTERVAL 5 MONTH AS cm_plus_5M,
now( ) - INTERVAL 5 YEAR AS cy_minus_5Y,
now( ) + INTERVAL 5 YEAR AS cy_plus_5Y
注意这里利用interval、数字及年月日单位(year,month,day,大小写无关),其中now代表当前日期时间,你可以用自己表中的日期值。当然,也可利用date_add函数来实现,形如这样:
select date_add(now(),interval -5 day) as cd_minus_5D
2)Oralce的日期加减操作语句(员工雇用日期为操作数),类似如下:
select hiredate -5 as hd_minus_5D,hiredate + 5 as hd_plus_5D,
add_months(hiredate,5) as hd_minus_5M,
add_months(hiredate,5) as hd_plus_5M,
add_months(hiredate,-5*12) as hd_minus_5Y,
add_months(hiredate,5*12) as hd_plus_5Y
from employee
其它的数据库就不举例了,有兴趣自己研究一下,再动手操练一下吧 ^_^ 。


SQL点滴(50):如何计算两个日期间的天数?



也就是求两个日期间相差的天数。例如计算两个员工间雇用日期相差天数。下面我们来看看如何实现?
1)在MySQL中的写法示例:
SELECT
datediff( ml_hd, zh_hd )
FROM
( SELECT hiredate AS ml_hd FROM employee WHERE ename = '马力' ) x,
( SELECT hiredate AS zh_hd FROM employee WHERE ename = '郑合' ) y
注意,datediff在MS SQL中同样有效,只是得在函数的第一个参数为day,而其他的不便,只要把函数改成datediff(day, ml_hd, zh_hd ) 即可。注意这里针对一个表查询,只能是子查询。
2)在Oracle中的示例写法:
select ml_hd - zh_hd
from
( SELECT hiredate AS ml_hd FROM employee WHERE ename = '马力' ) x,
( SELECT hiredate AS zh_hd FROM employee WHERE ename = '郑合' ) y
这个写法也适用PostgreSQL。
3)BD2中写法:
子查询同上面的一样,只是得用days函数,把第一个select后换成days(mz_hd)-days(zl_hd),即可。
好了,试试吧 ^_*

本篇就辑录到这,点个赞,分享出去吧。

相关推荐

Github霸榜的SpringBoot全套学习教程,从入门到实战,内容超详细

前言...

SpringBoot+LayUI后台管理系统开发脚手架

源码获取方式:关注,转发之后私信回复【源码】即可免费获取到!项目简介本项目本着避免重复造轮子的原则,建立一套快速开发JavaWEB项目(springboot-mini),能满足大部分后台管理系统基础开...

Spring Boot+Vue全栈开发实战,中文版高清PDF资源

SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...

2021年超详细的java学习路线总结—纯干货分享

本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础...

探秘Spring Cache:让Java应用飞起来的秘密武器

探秘SpringCache:让Java应用飞起来的秘密武器在当今快节奏的软件开发环境中,性能优化显得尤为重要。SpringCache作为Spring框架的一部分,为我们提供了强大的缓存管理能力,让...

3,从零开始搭建SSHM开发框架(集成Spring MVC)

目录本专题博客已共享在(这个可能会更新的稍微一些)https://code.csdn.net/yangwei19680827/maven_sshm_blog...

Spring Boot中如何使用缓存?超简单

SpringBoot中的缓存可以减少从数据库重复获取数据或执行昂贵计算的需要,从而显著提高应用程序的性能。SpringBoot提供了与各种缓存提供程序的集成,您可以在应用程序中轻松配置和使用缓...

我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

1,从零开始搭建SSHM开发框架(环境准备)

目录本专题博客已共享在https://code.csdn.net/yangwei19680827/maven_sshm_blog1,从零开始搭建SSHM开发框架(环境准备)...

做一个适合二次开发的低代码平台,把程序员从curd中解脱出来-1

干程序员也有好长时间了,大多数时间都是在做curd。现在想做一个通用的curd平台直接将我们解放出来;把核心放在业务处理中。用过代码生成器,在数据表设计好之后使用它就可以生成需要的controller...

设计一个高性能Java Web框架(java做网站的框架)

设计一个高性能JavaWeb框架在当今互联网高速发展的时代,构建高性能的JavaWeb框架对于提升用户体验至关重要。本文将从多个角度探讨如何设计这样一个框架,让我们一起进入这段充满挑战和乐趣的旅程...

【推荐】强&amp;牛!一款开源免费的功能强大的代码生成器系统!

今天,给大家推荐一个代码生成器系统项目,这个项目目前收获了5.3KStar,个人觉得不错,值得拿出来和大家分享下。这是我目前见过最好的代码生成器系统项目。功能完整,代码结构清晰。...

Java面试题及答案总结(2025版持续更新)

大家好,我是Java面试分享最近很多小伙伴在忙着找工作,给大家整理了一份非常全面的Java面试场景题及答案。...

Java开发网站架构演变过程-从单体应用到微服务架构详解

Java开发网站架构演变过程,到目前为止,大致分为5个阶段,分别为单体架构、集群架构、分布式架构、SOA架构和微服务架构。下面玄武老师来给大家详细介绍下这5种架构模式的发展背景、各自优缺点以及涉及到的...

本地缓存GuavaCache(一)(guava本地缓存原理)

在并发量、吞吐量越来越大的情况下往往是离不开缓存的,使用缓存能减轻数据库的压力,临时存储数据。根据不同的场景选择不同的缓存,分布式缓存有Redis,Memcached、Tair、EVCache、Aer...