Clickhouse异常:Exception: No operation equals between Decimal(X, X) and Float64

在使用clickhouse中的Decimal类型存储数字时,使用Decimal类型字段作为查询条件时,比如:

SELECT COUNT(*) AS total FROM table WHERE ( my_number=10.2)

会报错如下:Exception: No operation equals between Decimal(X, X) and Float64

原因是clickhouse会将10.2认为是float64类型,不是decimal类型,无法互转。

一般方法是可以用数据自带的转换函数,如:

SELECT COUNT(*) AS total FROM table WHERE ( my_number= toDecimal(10.2, 2))

SELECT COUNT(*) AS total FROM table WHERE ( toFloat64(my_number)= 10.2)

但是如果是在我们的mybatis-plus的wrapper条件代码里就不好用了,如:

.eq(TableModel::getMyNumber, 5.2d)

不管Decimal映射的java类型是Double还是BigDecimal都会报错,说到底它还是到数据库执行时报错了。

后来我发现,clickhouse会把字符串成功转成Decimal,而不会把数字转成Decimal,如下:

SELECT COUNT(*) AS total FROM table WHERE ( my_number= '10.2')

所以修改mybatis-plus的wrapper查询条件代码如下:

.eq(TableModel::getMyNumber, "5.2")

就可以成功了。

相关推荐
涛思数据(TDengine)33 分钟前
虚拟表、TDgpt、JDBC 异步写入…TDengine 3.3.6.0 版本 8 大升级亮点
大数据·数据库·tdengine
betazhou1 小时前
sqlserver2017 分离附加数据库
数据库·oracle·sqlserver
我是小木鱼1 小时前
浅析Centos7安装Oracle12数据库
linux·运维·服务器·数据库
Arbori_262151 小时前
oracle 表空间(Tablespace)
数据库·oracle
茉莉玫瑰花茶1 小时前
线程同步与互斥(下)
linux·数据库
BUG 劝退师1 小时前
MySQL数据库编程总结
数据库·mysql
viperrrrrrrrrr72 小时前
大数据学习(104)-clickhouse与hdfs
学习·clickhouse
notfindjob2 小时前
QT Sqlite数据库-教程001 创建数据库和表-上
数据库
亚林瓜子2 小时前
docker compose方式安装ClickHouse数据库
数据库·clickhouse·docker·mac·m1
04Koi.2 小时前
Redis进阶--哨兵
数据库·redis·缓存