阿里云-DataWorks- ODPS SQL开发3-日期与字符、数学运算、聚合函数函数

简介: 阿里云-DataWorks- ODPS SQL开发3 本文主要讲解日常大量会接触到的一些常用的日期与字符、数学运算、聚合函数函数。

前言

本文主要讲解日常大量会接触到的一些常用的日期与字符、数学运算、聚合函数函数

一、日期函数

GETDATE函数: 获取当前系统时间
SELECT GETDATE();
执行结果: 2022-12-15 20:33:23

DATEADD函数: 日期增减
SELECT DATEADD(GETDATE(),1,'dd');
执行结果: 2021-06-28 20:34:17

SELECT DATEADD(GETDATE(),-1,'dd');

执行结果: 2021-06-26 20:34:30

DATEDIFF函数: 计算返回时间差值

SELECT DATEDIFF('2022-12-15 20:33:23','2022-12-13 20:33:23','dd');
执行结果: 2
SELECT DATEDIFF('2022-12-15 20:33:23','2022-11-15 20:33:23','mm');
执行结果: 1
SELECT DATEDIFF('2022-12-15 20:33:23','2021-12-15 20:33:23','yyyy');
执行结果: 1
SELECT DATEDIFF('2022-12-15 20:33:23','2022-12-15 16:33:23','hh');
执行结果: 4
SELECT DATEDIFF('2022-12-15 20:33:23','2022-12-15 20:10:23','mi');
执行结果: 23
SELECT DATEDIFF('2022-12-15 20:33:23','2022-12-15 20:33:10','ss');
执行结果: 13

ADD_MONTHS函数: 计算月
SELECT ADD_MONTHS('2021-6-27',-1);
执行结果: 2022-11-15

DATEPART函数: 提取日期中part指定的部分
SELECT DATEPART('2022-12-15 20:33:23','yyyy');
执行结果: 2021

SELECT DATEPART('2022-12-15 20:33:23','mm');
执行结果: 6

SELECT DATEPART('2022-12-15 20:33:23','dd');
执行结果: 27

SELECT DATEPART('2022-12-15 20:33:23','hh');
执行结果: 19

SELECT DATEPART('2022-12-15 20:33:23','mi');
执行结果: 33

SELECT DATEPART('2022-12-15 20:33:23','ss');
执行结果: 23

DATETRUNC函数: 返回截取后的日期值
SELECT DATETRUNC('2022-12-15 20:33:23','yyyy');
执行结果: 2021-01-01 00:00:00

SELECT DATETRUNC('2022-12-15 20:33:23','mm');
执行结果: 2021-06-01 00:00:00

SELECT DATETRUNC('2022-12-15 20:33:23','dd');
执行结果: 2022-12-15 00:00:00

SELECT DATETRUNC('2022-12-15 20:33:23','hh');
执行结果: 2022-12-15 20:00:00

SELECT DATETRUNC('2022-12-15 20:33:23','mi');
执行结果: 2022-12-15 20:33:00

SELECT DATETRUNC('2022-12-15 20:33:23','ss');
执行结果: 2022-12-15 20:33:23

UNIX_TIMESTAMP函数: 将日期转化为整型的unix格式的日期时间值
SELECT UNIX_TIMESTAMP();
执行结果: 1624795597

FROM_UNIXTIME函数: 将数字型的unix 时间日期值转为DE日期值
SELECT FROM_UNIXTIME(1624795597);
执行结果: 2022-12-15 20:06:37

ISDATE函数: 判断一个日期字符串能否根据对应的格式串转换为一个日期值
SELECT ISDATE('2022-12-15 20:33:23','yyyy-mm-dd hh:mi:ss');
执行结果: true

LASTDAY函数: 取一个月的最后一天,截取到天
SELECT LASTDAY('2022-12-15 20:33:23');
执行结果: 2021-06-30 00:00:00

TO_DATE函数: 将一个字符串按照FORMAT指定的格式转成日期值
SELECT TO_DATE('2022-12-15 20:33:23','yyyy-mm-dd hh:mi:ss');
执行结果: 2022-12-15 20:13:41

TO_CHAR函数: 日期类型按照format指定的格式转成字符串
SELECT TO_CHAR(GETDATE(),'yyyy-mm-dd hh:mi:ss');
执行结果: 2022-12-15 20:17:26

WEEKDAY函数: 返回一个日期值是星期几
SELECT WEEKDAY(GETDATE());
执行结果: 6
星期一:0
星期二:1
星期三:2
星期四:3
星期五:4
星期六:5
星期天:6

WEEKOFYEAR函数: 返回一个日期位于那一年的第几周
SELECT WEEKOFYEAR(GETDATE());
执行结果: 25

二、数学运算函数

ABS函数: 绝对值函数
SELECT ABS(-1.567);
执行结果: 1.567

ACOS函数: 反余弦函数
SELECT ACOS(0.789);
执行结果: 0.6616166568777674

ASIN函数: 反正弦函数
SELECT ASIN(0.789);
执行结果: 0.9091796699171293

ATAN函数: 反正切函数
SELECT ATAN(0.789);
执行结果: 0.6679975427240679

CONV函数: 进制转换函数
SELECT CONV(100,10,2);
执行结果: 1100100

SELECT CONV(10101100,2,10);
执行结果: 172

COS函数: 余弦函数,输入为弧度值
SELECT COS(0.789);
执行结果: 0.7045553168836329

COSH函数: 双曲余弦函数
SELECT COSH(0.789);
执行结果: 1.3277464991182242

COT函数: 余切函数
SELECT COT(0.789);
执行结果: 0.992822149200644

EXP函数:指数函数(以e=2.718281828459045为底数)
SELECT EXP(3);
执行结果: 20.085536923187668

RAND函数: 随机数函数,返回double类型的随机数,返回值区间是的0~1
SELECT RAND(99);
执行结果: 0.9610280566667337

ROUND函数: 四舍五入到指定小数点位置
SELECT ROUND(0.789,2);
执行结果: 0.79

FLOOR函数: 向下取整
SELECT FLOOR(9.789);

执行结果: 9

SIN函数: 正弦函数
SELECT SIN(0.789);
执行结果: 0.7096490720426566

SINH函数: 双曲正弦函数
SELECT SINH(0.789);
执行结果: 0.8734476320425288

SQRT函数: 计算平方根
SELECT SQRT(9);
执行结果: 3.0

TAN函数: 正切函数
SELECT TAN(0.789);
执行结果: 1.0072297448290564

TANH函数: 双曲正切函数
SELECT TANH(0.789);
执行结果: 0.65784216537012

TRUNC函数: 截取函数,将输入值截取到指定小数点位置
SELECT TRUNC(987.789,1);
执行结果: 987.7

LN函数: 返回number的自然对数
SELECT LN(20.085536923187668);
执行结果: 3.0

LOG函数: 对数函数
SELECT LOG(2,3);
执行结果: SELECT LOG(2,3);

POW函数: 返回x的y次方,即x^y
SELECT POW(2,3);
执行结果: 8.0

CEIL函数: 向上取整
SELECT CEIL(9.789);
执行结果: 10

三、字符串处理函数

CHR函数: 将给定ASCII转换成字符,参数范围是0~255
SELECT CHR(90);
执行结果: Z

CONCAT函数: 字符串连接函数,将参数中的所有字符串连接在一起的结果
SELECT CONCAT('厦门在','福建');
执行结果: 厦门在福建

IN函数: 查看key是否在给定列表中出现
SELECT 99 IN(9,99,999,9999,99999);
执行结果: true

INSTR函数: 计算一个子串在字符串中的位置
SELECT INSTR('崇明在中国的上海','福建');

LENGTH函数: 返回一个字符串的长度
SELECT LENGTH('崇明在中国的上海');

LENGTHB函数: 返回一个字符串的以字节为单位的长度
SELECT LENGTHB('崇明在中国的上海');

MD5函数: 输入字符串的md5值
SELECT MD5('崇明在中国的上海');
执行结果: ac17f49e2f2e778634dee072e1dfc4ac

SPLIT_PART函数: 拆分字符串,返回指定的部分
SELECT SPLIT_PART('福州;厦门;泉州',';',2);
执行结果: 厦门

TO_CHAR函数: 返回对应值的字符串

SELECT TO_CHAR(99.98);

执行结果: 99.98

SUBSTR函数: 返回字符串string1从start_position开始长度为length的子串
SELECT SUBSTR('崇明在中国的上海',7,2);
执行结果: 上海

TOLOWER函数: 字符串转换为小写,输入字符串对应的小写字符串

SELECT TOLOWER('abcDEFGH');
执行结果: abcdefgh

TOUPPER函数: 字符串转换为大写,输入字符串对应的大写字符串
SELECT TOUPPER('abcDEFGH');
执行结果: ABCDEFGH

TRIM函数: 截取两端空格,将输入字符串去除左右空格
SELECT TRIM(' 崇明在中国的上海 ');
执行结果: 崇明在中国的上海

WM_CONCAT函数: 用指定的spearator做分隔符,做字符串类型的连接操作
SELECT WM_CONCAT(';',tt.id) as result
FROM NOTE_INFO_TEST tt
WHERE tt.area = '340000';
执行结果: 2021002;2021004;2021001;2021005;2021003

四、聚合函数

AVG函数: 计算平均值
SELECT AVG(tt.money) AS RESULT FROM NOTE_INFO_TEST tt;

COUNT函数: 计算数目
SELECT COUNT(1) AS RESULT FROM NOTE_INFO_TEST tt;

MAX函数: 计算最大值
SELECT MAX(tt.money) AS RESULT FROM NOTE_INFO_TEST tt;

MEDIAN函数: 中位数
SELECT MEDIAN(tt.money) AS RESULT FROM NOTE_INFO_TEST tt;

MIN函数: 计算最小值
SELECT MIN(tt.money) AS RESULT FROM NOTE_INFO_TEST tt;

SUM函数: 求和
SELECT SUM(tt.money) AS RESULT FROM NOTE_INFO_TEST tt;

相关实践学习
基于Hologres轻量实时的高性能OLAP分析
本教程基于GitHub Archive公开数据集,通过DataWorks将GitHub中的项⽬、行为等20多种事件类型数据实时采集至Hologres进行分析,同时使用DataV内置模板,快速搭建实时可视化数据大屏,从开发者、项⽬、编程语⾔等多个维度了解GitHub实时数据变化情况。
相关文章
|
5月前
|
存储 分布式计算 大数据
【赵渝强老师】阿里云大数据存储计算服务:MaxCompute
阿里云MaxCompute是快速、全托管的TB/PB级数据仓库解决方案,提供海量数据存储与计算服务。支持多种计算模型,适用于大规模离线数据分析,具备高安全性、低成本、易用性强等特点,助力企业高效处理大数据。
277 0
|
5月前
|
数据采集 人工智能 大数据
10倍处理效率提升!阿里云大数据AI平台发布智能驾驶数据预处理解决方案
阿里云大数据AI平台推出智能驾驶数据预处理解决方案,助力车企构建高效稳定的数据处理流程。相比自建方案,数据包处理效率提升10倍以上,推理任务提速超1倍,产能翻番,显著提高自动驾驶模型产出效率。该方案已服务80%以上中国车企,支持多模态数据处理与百万级任务调度,全面赋能智驾技术落地。
601 0
|
3月前
|
人工智能 分布式计算 DataWorks
阿里云大数据AI产品月刊-2025年8月
阿里云大数据& AI 产品技术月刊【2025年 8 月】,涵盖 8 月技术速递、产品和功能发布、市场和客户应用实践等内容,帮助您快速了解阿里云大数据& AI 方面最新动态。
336 2
|
3月前
|
存储 分布式计算 资源调度
【赵渝强老师】阿里云大数据MaxCompute的体系架构
阿里云MaxCompute是快速、全托管的EB级数据仓库解决方案,适用于离线计算场景。它由计算与存储层、逻辑层、接入层和客户端四部分组成,支持多种计算任务的统一调度与管理。
321 1
|
5月前
|
人工智能 分布式计算 DataWorks
多模态数据处理新趋势:阿里云ODPS技术栈深度解析与未来展望
阿里云ODPS技术栈通过MaxCompute、Object Table与MaxFrame等核心组件,实现了多模态数据的高效处理与智能分析。该架构支持结构化与非结构化数据的统一管理,并深度融合AI能力,显著降低了分布式计算门槛,推动企业数字化转型。未来,其在智慧城市、数字医疗、智能制造等领域具有广泛应用前景。
499 6
多模态数据处理新趋势:阿里云ODPS技术栈深度解析与未来展望
|
存储 机器学习/深度学习 人工智能
阿里云ODPS:在AI浪潮之巅,铸就下一代智能数据根基
在智能爆炸时代,ODPS正从传统数据平台进化为“AI操作系统”。面对千亿参数模型与实时决策挑战,ODPS通过流批一体架构、多模态处理、智能资源调度等技术创新,大幅提升效率与智能化水平。从自动驾驶到医疗联合建模,从数字孪生到低代码AI开发,ODPS正重塑企业数据生产力,助力全球客户在算力洪流中抢占先机。
204 0