欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

mybatis sum(参数) 列名作为参数的问题

时间:2023-01-23 08:25:20|栏目:JAVA代码|点击:

sum(参数) 列名作为参数

项目中有很多个字段,当字段为空的时候,求该列的平均值并赋值给该字段。如:

     
id name age

当我需要插入一条数据的时候,这条数据的age为空,那么需要先从数据库查询age的平均值,然后赋值给当前的数据。当字段很多的时候就需要列名作为参数查询了

mapper.xml

  <select id="getGtAvg" parameterType="java.lang.String" resultType="bigDecimal">
    select avg(${columnName})
    from tb_chuai
    where ${columnName} &gt; 0
  </select>

DAO

BigDecimal getGtAvg(@Param("columnName") String columnName);

注意事项

1、 聚合函数,如sum、avg等resultType为bigDecimal或者integer类型

2、${}一般用于传输数据库的表名、字段名等,不能使用#{}

3、mysql中的varchar可以进行sum,avg等操作,但是其中的汉字作为0,计算avg平均值的时候可能出现问题。

mybatis注解sql sum(参数)传参写法

验证了很久sum()里面带参数方式 #{参数}一直不行日志显示参数已经传进 但就是加不上去 返回的始终是0

后面换成$(参数)之后就行了

@Select("select sum(${type}) from "+ TABLE_HOUR + " where date_format(`date`,'%Y-%m-%d') = #{date}")
public int selectDay2(@Param("date") String date,@Param("type") String type);

上一篇:SpringBoot中Starter的作用小结

栏    目:JAVA代码

下一篇:vscode快速引入第三方jar包发QQ邮件

本文标题:mybatis sum(参数) 列名作为参数的问题

本文地址:http://www.codeinn.net/misctech/224279.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有