本文主要是介绍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")
就可以成功了。
这篇关于Clickhouse异常:Exception: No operation equals between Decimal(X, X) and Float64的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!