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")

就可以成功了。

相关推荐
iuvtsrt几秒前
如何添加超链接_a标签href属性详解【详解】
jvm·数据库·python
2401_86762398几秒前
CSS如何快速获取网页上的标准色值_借助开发者工具的取色器和色彩格式转换功能
jvm·数据库·python
学习,学习,在学习1 分钟前
Qt多线程的使用与注意事项
开发语言·数据库·qt
zhaoyong2223 分钟前
JavaScript中骨架屏Skeleton在异步数据加载中应用
jvm·数据库·python
m0_591364736 分钟前
C#怎么使用LINQ OrderBy排序 C#如何用LINQ对集合按多个字段进行升序降序排列【语法】
jvm·数据库·python
m0_733565466 分钟前
HTML函数开发需要独立显卡吗_HTML函数与显卡关系详解【说明】
jvm·数据库·python
2401_884454159 分钟前
Python测试代码如何实现自解释_使用pytest描述性命名规范
jvm·数据库·python
.柒宇.12 分钟前
Redis哨兵模式搭建
数据库·redis·哨兵
dinglu1030DL17 分钟前
Go语言怎么格式化时间_Go语言time.Format教程【详解】
jvm·数据库·python
环流_21 分钟前
Redis单线程但效率高且快
数据库·redis·缓存