SQL函数学习记录

聚合函数

函数是编程语言的基础之一,在对数字的运算中,我们用的最多的就是聚合函数,本篇接下来就详细阐述下SQL中聚合函数的运用。

什么是聚合函数(aggregate function)?

聚合函数指的是对一组值执行计算并返回单一的值。

常见聚合函数:

  • 求个数、记录条数的count

select conut(*)/count(1) from 表名;

count_if函数

count_if(boolean expression) //参数值为布尔表达式,返回为interge;

eg:

统计request_uri字段的值是以file-0结尾的日志条数。

SELECT count_if(request_uri like'%file-0') AS count from 表名;

  • 求合计数的sum

select sum(age) from 表名;

  • 求平均数的avg

select avg(age) from 表名;

  • 求最大值、最小值的max(),min()

select max(age) from 表名;

select min(age) from 表名;

附:max函数

max(x) 查询x中的最大值;

max(x,n) 查询x中最大的n个值,返回为数组;

eg:SELECT max(request_time,10) AS "top 10" from 表名;

mysql语法:SELECT max(money,3) AS "top 3" from TableC order by money desc;

利用如下数据库进行演示:

select * from TableC;

(1)分别算出各部门的人数、总业绩、平均业绩;

SELECT bm,count(name) 人数,sum(money) 总业绩,avg(money) 平均业绩 from TableC group by bm;

(2)公司要对各部门业绩最好的员工进行奖励,现在需要统计出每个部门业绩最好的员工信息,并展示业绩是多少;

select a.* from TableC a inner join (select bm,max(money) as money from TableC group by bm) b on a.bm=b.bm and a.money=b.money;

//通过部门和money列联系起来的,inner join 表a 表b on 联系条件

(3)显示总money超过300w的部门业绩明细;

select a.*from TableC a where bm in (select bm from TableC group by bm having sum(money)>300);

补充下与group by 联用的order by ,再提个用法,针对上面的例子,要查全公司里,业绩前三的员工及业绩,代码如下:

select top 3 * from TableC order by money desc;

//desc 降序排列,mysql不支持top命令;

mysql语法:

select * from TableC order by money desc LIMIT 3;

HAVING语句

Having语句是对分组之后的数据进行过滤,因此使用having前通常会使用group by;

select a.*from TableC a where bm in (select bm from TableC group by bm having sum(money)>300);

GROUP BY 语句

结合聚合函数,根据一个或多个列对分析结果进行分组。还支持搭配rollupcubegroupping sets语句扩展分组功能。

  • group by :对分析结果进行分组;

语法:

SELECT key,...aggregate function GROUP BY key,...//参数解释:key:日志字段名称或聚合函数结果列,支持单列或多列;aggregate function:聚合函数。GROUP BY子句常与min、max、avg、sum、count等聚合函数       搭配使用。

示例:统计不同状态码对应的请求次数:

select status count(*) AS PV group by status;

示例:按照每小时的时间粒度计算网站访问PV。其中,__time__字段为日志服务中的保留字段,表示时间列。timedate_trunc('hour', __time__)的别名。date_trunc函数的更多信息,请参见date_trunc函数。

SELECTcount(*) AS PV,date_trunc('hour', __time__) AS time
GROUP BYtime
ORDER BYtime
LIMIT1000                       

date_trunc函数

date_trunc函数会根据您指定的时间单位截断日期和时间表达式,并按照毫秒、秒、分钟,小时、日、月或年对齐。该函数常用于需要按照时间进行统计分析的场景。

语法:

date_trunc(unit, x)//--unity:时间单位,取值为millisecond、second、minute、hour、day、week、month、quarter、year。请参见unit说明。
//--x:参数值为日期和时间表达式。

date_trunc函数只能按照固定的时间间隔统计(例如每分钟、每小时等)。如果您需要按照灵活的时间维度统计,请使用数学取模方法进行分组,例如统计每5分钟的数据。

SELECTcount(1) AS pv, __time__ - __time__ %300AStimeGROUPBYtime LIMIT 100;

示例:

按照每分钟的时间粒度计算请求时间的平均值,并按照时间进行分组和排序。

SELECTdate_trunc('minute', __time__) AS time,truncate (avg(request_time)) AS avg_time,current_date AS date
GROUP BY time
ORDER BY time DESC
LIMIT 100;

SPLIT函数/SPLIT_PART函数

split函数通过指定的分隔符拆分字符串,并返回拆分后的子串集合。

split_part函数通过指定的分隔符拆分字符串,并返回指定位置的内容。

语法:

split (x,delimeter,limit)

split_part(x,delimiter,part)

示例:

select split(runoob_authour,'/',3) from runoon_tbl where runoob_id='19';

SELECT count(*), split_part(runoob_author, '?', 1) from runoon_tbl where runoob_id='19';

split_to_map函数

split_to_map函数用于使用指定的第一个分隔符拆分字符串,然后再使用指定的第二个分隔符进行第二次拆分。

语法:

split_to_map(x, delimiter01, delimiter02)

示例:

使用英文逗号(,)和英文冒号(:)拆分time字段的值,返回结果为MAP类型。

time:upstream_response_time:"80", request_time:"40"

select split_to_map(time,',',':') from xxxx

日期和时间函数

  • current_date函数

语法:current_date //返回当前日期,格式为YYY-MMM-DDD;

示例:

  • current_time函数

语法:current_time //返回当前日期和时区;

  • current_timesamp函数

语法:current_timesamp //返回当前日期、时间和时区;

  • current_timezone函数

语法:current_timezone() //返回当前时区;

  • date函数

语法:date(x) //返回当前日期和时间中的日期部分;

  • localtime函数

语法:localtime //返回本地时间;

  • localtimestamp函数

语法:localtimestamp //返回本地日期和时间;

  • now函数

语法:now() //返回当前日期和时间,同current_timesamp函数

  • day函数=day_of_month函数

语法:day(x) 或 day_of_month(x) //提取日期和时间表达式中的天数,按月计算。

  • day_of_week函数=dow函数,doy函数=day_of_year函数

语法:day_of_week(),dow(),doy(),day_of_year() //提取日期和时间表达式中的天数,按周或年计算。

  • date_add函数

语法:date_add(unit,N,x) //在x上加伤N个时间单位。

sql拆分

SQL 一行转多行的处理方案_sql一行拆分成多行-CSDN博客

--存量域名查询sql
SELECT COUNT(newlist) as newnum,newlist FROM(
SELECT  
-- explode(list) as newlist 
EXPLODE(split(list, ';')) as newlist
FROM    afscdm.dwd_sec_evt_cloudshell_oneagent_white_domain_alert_hi
WHERE  dt>'20220811'and dt<'20220819'
--and hour="12"
LIMIT 9999) group by newlist 
HAVING 
newlist not like "%ping%" AND   newlist not like "%onlinedown%" 
AND   newlist NOT like  "%svchost%"
order by newnum DESC limit 10;

odps/Hive中一行转多行

  • explode()内置函数

接收一个array或map类型的数据作为输入(用split函数生成数组),然后将array或map里面的元素按照每行的形式输出。

  • split()函数

split()通过指定分隔符对字符串进行切片,如果参数num有指定值,则只分割n+1个子字符串。

语法:str.split(str=" ",num=string.count(str))

参数介绍:

    • sep--可选参数,指定分隔符,默认为所有的空字符,包括空格" ",换行\n,制表\t等。
    • count--可选参数,分割次数,默认为空字符在字符串中出现的次数。

使用案例:

str = "this is string example....wow!!!"
print(str.split())
print(str.split("i", 1))
print(str.split("w"))# 结果为
# ['this', 'is', 'string', 'example....wow!!!']
# ['th', 's is string example....wow!!!']
# ['this is string example....', 'o', '!!!']@@@@@@@@@@@@@@以#为分隔符,指定第二个参数为2,返回3个参数列表@@@@@@@@@@@@@@@@@@@@@@@@@tst = "Google#Runoob#Taobao#Facebook"
print(tst.split("#", 2))# 结果为
# ['Google', 'Runoob', 'Taobao#Facebook']

附:

创建表:create table TableC (gh varchar(8),name varchar(8),bm varchar(8),money int(255));

插入表数据:insert into TableC values ('003','何三','销售1部',150);

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

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

相关文章

Pytorch模型训练后静态量化并加载int8量化模型推理

目录 一、源码包准备1.1 源码包获取1.2 代表性验证集1.3 Pytorch模型1.4 推理测试图片 二、环境准备三、模型转换3.1 参数修改3.2 代码3.3 量化转换结果3.4 量化前后模型大小对比 四、量化模型推理4.1 参数修改4.2 代码4.3 推理结果4.4推理时间 五、总结 一、源码包准备 1.1 源…

什么是Sectigo?如何优惠申请?

Sectigo&#xff0c;全球领先的SSL/TLS证书提供商&#xff0c;以其卓越的安全性能和广泛的认可度赢得了业界的一致好评。我们的证书不仅能加密您的网站通信&#xff0c;确保敏感信息传输过程中的绝对安全&#xff0c;还能显著提升您的网站信誉&#xff0c;让访客一眼就能识别出…

价格战打响!阿里云服务器和腾讯云服务器价格对比

2024年阿里云服务器和腾讯云服务器价格战已经打响&#xff0c;阿里云服务器优惠61元一年起&#xff0c;腾讯云服务器62元一年&#xff0c;2核2G3M、2核4G、4核8G、8核16G、16核32G、16核64G等配置价格对比&#xff0c;阿腾云atengyun.com整理阿里云和腾讯云服务器详细配置价格表…

什么是VR紧急情况模拟|消防应急虚拟展馆|VR游戏体验馆加盟

VR紧急情况模拟是利用虚拟现实&#xff08;Virtual Reality&#xff0c;简称VR&#xff09;技术来模拟各种紧急情况和应急场景的训练和演练。通过VR技术&#xff0c;用户可以身临其境地体验各种紧急情况&#xff0c;如火灾、地震、交通事故等&#xff0c;以及应对这些紧急情况的…

第三百七十四回

文章目录 1. 概念介绍2. 实现方法2.1 基本用法2.2 特殊用法 3. 示例代码4. 内容总结 我们在上一章回中介绍了"分享三个使用TextField的细节"相关的内容&#xff0c;本章回中将介绍如何让Text组件中的文字自动换行.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1.…

leetcode刷题(剑指offer) 46.全排列

46.全排列 给定一个不含重复数字的数组 nums &#xff0c;返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,3] 输出&#xff1a;[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2&#xff1a; 输入&#…

STM32F103学习笔记(七) PWR电源管理(原理篇)

目录 1. PWR电源管理简介 2. STM32F103的PWR模块概述 2.1 PWR模块的基本工作原理 2.2 电源管理的功能和特点 3. PWR模块的常见应用场景 4. 常见问题与解决方案 1. PWR电源管理简介 PWR&#xff08;Power&#xff09;模块是STM32F103系列微控制器中的一个重要组成部分&…

C语言 变量

变量其实只不过是程序可操作的存储区的名称。C 中每个变量都有特定的类型&#xff0c;类型决定了变量存储的大小和布局&#xff0c;该范围内的值都可以存储在内存中&#xff0c;运算符可应用于变量上。 变量的名称可以由字母、数字和下划线字符组成。它必须以字母或下划线开头…

导出数据库表结构到文档中

导出效果&#xff1a; 完整代码&#xff1a; Controller层&#xff1a; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotatio…

Android Stdio Execution failed for task ‘:app:compileDebugKotlin‘ 报错解决

具体报错信息如下&#xff1a; compileDebugJavaWithJavac task (current target is 1.8) and compileDebugKotlin task (current target is 17)jvm target compatibility should be set to the same Java version.很显然&#xff0c;这是一个版本冲突问题&#xff0c;compile…

云上攻防-云服务篇弹性计算服务器云数据库实例元数据控制角色AK控制台接管

知识点: 1、云服务-弹性计算服务器-元数据&SSRF&AK 2、云服务-云数据库-外部连接&权限提升 章节点&#xff1a; 云场景攻防&#xff1a;公有云&#xff0c;私有云&#xff0c;混合云&#xff0c;虚拟化集群&#xff0c;云桌面等 云厂商攻防&#xff1a;阿里云&am…

Tomcat服务部署

1、安装jdk、设置环境变量并测试 第一步&#xff1a;安装jdk 在部署 Tomcat 之前必须安装好 jdk&#xff0c;因为 jdk 是 Tomcat 运行的必要环境。 1. #关闭防火墙 systemctl stop firewalld systemctl disable firewalld setenforce 02. #将安装 Tomcat 所需软件包传到/opt…

90%电商APP已沦落至无人下载,用户主观意愿——是真正实用性价值!

90%电商APP已沦落至无人下载&#xff0c;用户主观意愿——是真正实用性价值&#xff01; 文丨微三云营销总监胡佳东&#xff0c;点击上方“关注”&#xff0c;为你分享市场商业模式电商干货。 - 引言&#xff1a;在互联网发展的大时代下&#xff0c;似乎每个月都有新的APP出现…

Linux Shell脚本练习(一)

一、 Linux下执行Shell脚本的方式&#xff1a; 1、用shell程序执行脚本&#xff1a; a、根据你的shell脚本的类型&#xff0c;选择shell程序&#xff0c;常用的有sh&#xff0c;bash&#xff0c;tcsh等 b、程序的第一行#!/bin/bash里面指明了shell类型的&#xff0c;比如#!/…

Programming Abstractions in C阅读笔记:p306-p307

《Programming Abstractions in C》学习第75天&#xff0c;p306-p307总结&#xff0c;总计2页。 一、技术总结 1.Quicksort algorithm(快速排序) 由法国计算机科学家C.A.R(Charles Antony Richard) Hoare&#xff08;东尼.霍尔&#xff09;在1959年开发(develop), 1961年发表…

Windows下使用C++调用海康威视SDK获取实时视频流进行检测

目录 准备海康威视的SDK官网下载下载后解压 Vs 2022创建项目创建32位的环境 将相关文件复制到工程目录下工程配置海康威视SDK配置包含目录配置库目录将dll文件添加到环境中在附加依赖项添加如下内容 工程配置OpenCV配置工程配置包含目录配置库目录 测试 准备海康威视的SDK 官网…

位段 详解

目录 位段的声明位段的内存分配位段的跨平台问题 位段的声明 位段的声明和结构是类似的&#xff0c;有两个不同&#xff1a; 位段的成员必须是 int、unsigned int 或signed int位段的成员名后边有一个冒号和一个数字 例如&#xff0c;A是一个位段类型&#xff1a; struct A…

程序员的金三银四求职宝典

目录 简介&#xff1a; 1.准备简历&#xff1a; 2.强调技术能力&#xff1a; 3.建立个人品牌&#xff1a; 4.提前准备面试&#xff1a; 5.关注招聘信息渠道&#xff1a; 6.提前与内推&#xff1a; 7.心态调整&#xff1a; 结论&#xff1a; 简介&#xff1a; 金三银四是…

老卫带你学---leetcode刷题(130. 被围绕的区域)

130. 被围绕的区域 问题 给你一个 m x n 的矩阵 board &#xff0c;由若干字符 ‘X’ 和 ‘O’ &#xff0c;找到所有被 ‘X’ 围绕的区域&#xff0c;并将这些区域里所有的 ‘O’ 用 ‘X’ 填充。 示例 1&#xff1a; 输入&#xff1a;board [[“X”,“X”,“X”,“X”]…

基于相位的运动放大:如何检测和放大难以察觉的运动(02/2)

目录 一、说明二、算法三、准备处理四、高斯核五、带通滤波器六、复杂的可操纵金字塔七、最终预处理步骤八、执行处理九、金字塔的倒塌十、可视化结果十一、结论 一、说明 日常物体会产生人眼无法察觉的微妙运动。在视频中&#xff0c;这些运动的幅度小于一个像素&#xff0c;…