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 │
└───┘
相关推荐
XueminXu2 天前
ClickHouse数据库的表引擎
数据库·clickhouse·log·表引擎·mergetree·special·integrations
MQ不会写文章2 天前
Clickhouse语法及配置
clickhouse
songroom7 天前
dbpystream webapi: 一次clickhouse数据从系统盘迁至数据盘的尝试
后端·clickhouse·阿里云
weixin_307779139 天前
Linux 下 Docker 与 ClickHouse 的安装配置及 MySQL 数据同步指南
linux·数据库·mysql·clickhouse·运维开发
bigdata-rookie10 天前
ClickHouse 介绍
clickhouse
MARSERERER12 天前
ClickHouse迁移Starrocks脚本工具
starrocks·clickhouse
赤月幼狼12 天前
clickhouse学习笔记(一)基础概念与架构
笔记·学习·clickhouse
草明13 天前
clickhouse 检查是否有删除语句在执行
数据库·clickhouse
StarRocks_labs13 天前
从 ClickHouse 到 StarRocks 存算分离: 携程 UBT 架构升级实践
starrocks·clickhouse·存算分离·ubt架构·湖仓查询
大数据0017 天前
CLICKHOUSE分布式表初体验
分布式·clickhouse