温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

mybatis sum列名作为参数的实例分析

发布时间:2022-02-07 15:25:24 来源:亿速云 阅读:127 作者:iii 栏目:开发技术

本文小编为大家详细介绍“mybatis sum列名作为参数的实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“mybatis sum列名作为参数的实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    sum(参数) 列名作为参数

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

       
    idnameage

    当我需要插入一条数据的时候,这条数据的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);

    读到这里,这篇“mybatis sum列名作为参数的实例分析”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI