热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mybatis遇到Integer类型的参数时动态sql需要注意什么条件

这篇“mybatis遇到Integer类型的参数时动态sql需要注意什么条件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,

这篇“mybatis遇到Integer类型的参数时动态sql需要注意什么条件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mybatis遇到Integer类型的参数时动态sql需要注意什么条件”文章吧。

mybatis Integer类型参数动态sql注意条件

例如以下拼接的动态sql


 and T.status=#{work_status,jdbcType=INTEGER}

当work_status为0时,Mybatis会将0解析为了空字符串‘’,这样if判断就为false,如果想正确添加and后的查询条件,应该改成


 and T.status=#{work_status,jdbcType=INTEGER}

mybatis的坑——Integer类型参数解析问题

有时候我们使用实体类传递参数时

有些属性会被设置为Integer类型,比如status、sort等,在这里,使用Integer类型参数作为条件时,要注意一点:例如


        AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR}

这里对于bean.activitySort的判断正常情况下如果activitySort是String类型,先判空,再判断是否是空字符串,这样是正常的,但是如果activitySort是Integer类型参数,那么使用时就需要注意,此处不能对activitySort进行空字符串的判断,因为什么呢?

因为mybatis在解析Integer类型数据时

如果数据值为0,会将0解析为空字符串,这样你传入的参数就成为无效的了,所以正常使用Integer类型参数应该是下面这样:


        AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR}

以上就是关于“mybatis遇到Integer类型的参数时动态sql需要注意什么条件”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程笔记行业资讯频道。


推荐阅读
author-avatar
黎世江
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有