Clickhouse 算术函数操作总结—— Clickhouse 基础篇(五)

文章目录

加法函数

  • 加法函数不仅可以计算数字,还可以使用日期和时间来进行加法运算。
  • 日期加的是天数,时间加的是秒数。
sql 复制代码
SELECT 1+1;

select toDate('2024-05-01') + 1 AS d, toDateTime('2024-05-01 12:00:00') + 20 as t;
####################
┌──────────d─┬───────────────────t─┐
│ 2024-05-02 │ 2024-05-01 12:00:20 │
└────────────┴─────────────────────┘

减法函数

  • 和加法函数类似,也可以用于对日期和时间的计算
sql 复制代码
SELECT 1+1;

select toDate('2024-05-02') - 1 AS d, toDateTime('2024-05-01 12:00:30') - 20 as t;
####################
┌──────────d─┬───────────────────t─┐
│ 2024-05-01 │ 2024-05-01 12:00:10 │
└────────────┴─────────────────────┘

乘法函数

sql 复制代码
SELECT 1*3

浮点除法函数

  • 计算结果为浮点类型,除以0时,结果为 inf、-inf 或 nan.
sql 复制代码
SELECT
  1 / 0 AS a,
  0 / 0 AS b,
  8 / 4 AS c

####################
┌───a─┬───b─┬─c─┐
│ inf │ nan │ 2 │
└─────┴─────┴───┘

整数除法函数

  • 结果向下取舍,除0会报错
sql 复制代码
SELECT 
  intDiv(7, 3),
  7 / 3;
###################
┌─intDiv(7, 3)─┬───────divide(7, 3)─┐
│            2 │ 2.3333333333333335 │
└──────────────┴────────────────────┘

SELECT intDiv(1, 0);
###################
Received exception from server (version 22.12.6):
Code: 153. DB::Exception: Received from localhost:9000. DB::Exception: Division by zero: While processing intDiv(1, 0). (ILLEGAL_DIVISION)

带0整数除法函数

  • 和整数除法一样,但是该函数可以除0,除0 为 0
sql 复制代码
SELECT 
  intDivOrZero(1,0) AS a,
  intDivOrZero(1,2) AS b,
  intDivOrZero(5,3) AS c;
######################
┌─a─┬─b─┬─c─┐
│ 0 │ 0 │ 1 │
└───┴───┴───┘

取余函数

  • 被除数不能为0,为0报错
sql 复制代码
SELECT 
  7.7 % 3 AS a,
  7 % 3 AS b;
#################
┌──────────────────a─┬─b─┐
│ 1.7000000000000002 │ 1 │
└────────────────────┴───┘

带0取余函数

  • 被除数可以为0,为0 结果为0
sql 复制代码
SELECT
  moduloOrZero(1, 0) AS a,
  moduloOrZero(7, 3) AS b;

######################
┌─a─┬─b─┐
│ 0 │ 1 │
└───┴───┘

负数函数

sql 复制代码
SELECT 
 1 as a,
 -a;
##################
┌─a─┬─negate(1)─┐
│ 1 │        -1 │
└───┴───────────┘

绝对值函数

sql 复制代码
SELECT 
 -1 AS a,
 abs(a) AS b;
####################
┌──a─┬─b─┐
│ -1 │ 1 │
└────┴───┘

最大公约数函数

sql 复制代码
SELECT gcd(12, 16) AS a;
###############
┌─a─┐
│ 4 │
└───┘

最小公倍数函数

sql 复制代码
SELECT lcm(12, 16) AS a;
###############
┌─a─┐
│ 48 │
└───┘

最大数函数

sql 复制代码
SELECT max2(1 2) AS a;
###############
┌─a─┐
│ 2 │
└───┘

最小数函数

sql 复制代码
SELECT min2(1 2) AS a;
###############
┌─a─┐
│ 1 │
└───┘
相关推荐
阿里云大数据AI技术6 天前
鹰角网络基于阿里云 EMR Serverless StarRocks 的实时分析工程实践
starrocks·clickhouse·阿里云·emr·实时分析
更深兼春远9 天前
flink+clinkhouse安装部署
大数据·clickhouse·flink
Sais_Z12 天前
ClickHouse的学习与了解
数据库·clickhouse
风中凌乱15 天前
ClickHouse-Backup的安装与部署
clickhouse
风中凌乱15 天前
clickhouse集群的安装与部署
clickhouse
白眼黑刺猬15 天前
ClickHouse从入门到企业级实战全解析课程简介
clickhouse
chenglin01619 天前
ClickHouse、Doris、OpenSearch、Splunk、Solr系统化分析
clickhouse·solr·lucene
慕y27419 天前
Java学习第一百一十七部分——ClickHouse
java·学习·clickhouse
zuozewei24 天前
随笔之 ClickHouse 列式分析数据库安装注意事项及基准测试
数据库·clickhouse
牛牛木有坏心眼(大数据进阶)25 天前
linux系统离线环境安装clickhouse客户端
linux·clickhouse