mybatis group by substr函数传参报错的解决

网友投稿 963 2022-11-05

mybatis group by substr函数传参报错的解决

mybatis group by substr函数传参报错的解决

目录mybatis group by substr传参报错报异常原因使用group by 分组查http://询返回为null解决方法

mybatis group by substr传参报错

报异常

### Cause: java.sql.SQLSyntaxErrorException: ORA-00979: 不是 GROUP BY 表达式

SELECT

SUBSTR( region_code, 1,#{ queryMap.groupCodeLength, jdbcType = INTEGER } ) AS "region_code",

count( CASE WHEN TYPE = 1 THEN 0 END ) AS "like",

count( CASE WHEN TYPE = 2 THEN 0 END ) AS "roast"

FROM

t_pub_sentiment

WHERE

1 = 1

GROUP BY

SUBSTR(region_code,1,#{ queryMap.groupCodeLength,jdbcType = INTEGER })

更改后:

SELECT

SUBSTR( region_code, 1, $ { queryMap.groupCodeLength } ) AS "region_code",

count( CASE WHEN TYPE = 1 THEN 0 END ) AS "like",

count( CASE WHEN TYPE = 2 THEN 0 END ) AS "roast"

FROM

t_pub_sentiment

WHERE

1 = 1

GROUP BY

SUBSTR( region_code, 1, $ { queryMap.groupCodeLength } )

原因

#{} 和 ${} 在预编译中的处理是不一样的。#{} 在预处理时,会把参数部分用一个占位符 ? 代替。而 ${} 则只是简单的字符串替换。

${}有sql注SFGRWpRI入的风险,需谨慎使用。

使用group by 分组查询返回为null

我在使用mybatis进行分组查询时数据库有数据,但是mybatis返回为null,使用mybatis版本为3.4.1

解决方法

在resultMap的result标签中添加 property属性

如下:

select id,dept_name,count(1) from tbl_dept where dept_id=#{id} group by id;

我在第一次使用时没有添加property导致mybatis返回null,添加后就可以正常返回。

dao层代码

public List getDeptByIdStep(Integer id);

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Class文件结构介绍[常量池]
下一篇:Go web编程
相关文章

 发表评论

暂时没有评论,来抢沙发吧~