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 │
└───┘
相关推荐
unhurried人生——冕临1 天前
Ubuntu安装ClickHouse
clickhouse
爱吃萝卜的猪12 天前
Clickhouse源码分析-Replicated Database创建流程
clickhouse
编程的大耳朵12 天前
ClickHouse 概述
clickhouse
Ethan301413 天前
Clickhouse官方文档学习笔记
笔记·学习·clickhouse
weixin_3077791314 天前
Python实现MySQL建表语句转换成Clickhouse SQL
数据库·python·sql·mysql·clickhouse
大千AI助手23 天前
硬核实战 | 3分钟Docker部署ClickHouse列存数据库
大数据·clickhouse·docker·database
Sayai24 天前
dbeaver 查询clickhouse,数据库时间差了8小时
数据库·clickhouse·oracle
weixin_3077791325 天前
Clickhouse统计指定表中各字段的空值、空字符串或零值比例
运维·数据仓库·clickhouse
weixin_307779131 个月前
Linux下GCC和C++实现统计Clickhouse数据仓库指定表中各字段的空值、空字符串或零值比例
linux·运维·c++·数据仓库·clickhouse
斯特凡今天也很帅1 个月前
clickhouse常用语句汇总——持续更新中
数据库·sql·clickhouse