mybatis中的test语句失效怎么办
发表于:2025-01-16 作者:千家信息网编辑
千家信息网最后更新 2025年01月16日,这篇文章主要介绍了mybatis中的test语句失效怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。mybatis test语句失
千家信息网最后更新 2025年01月16日mybatis中的test语句失效怎么办
这篇文章主要介绍了mybatis中的test语句失效怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
mybatis test语句失效
正常情况下,写动态sql的if test或when test语句时,条件引用为双引号括单引号
如下:
但是今天发现一个问题,当传入的值为0或者1时,sql失效不被执行。
如下:
and user = #{user}
之后,发现是MyBatis自身解析的问题,在标签 中的内容,MyBatis是使用的OGNL表达式来进行解析的,这个地方需要注意下,单引号内有一个字符的情况下,OGNL会将其以 java 中的 char 类型进行解析,那么此时 char 类型与参数 String 类型用等号进行比较的时候结果都是false。
解决方案也很简单
就是把test 中的单个字符用双引号括起来。
mybatis test判断注意事项
在使用mybatis进行判断的时候,一定要注意传入的数据类型与判断的目标值类型是否一致。
最近在一次开发过程,
误将一个传入的整型数据使用了下面的判断方式
and a.c_appType = #{appType}
其中,appType是一个整型数据。可以看到,在test判断里面使用了 appType != ''。
在进行业务功能测试的时候发现,当传入的值是0时,该条件筛选没有起作用,通过调试发现,mybatis会将空字符串转换成double类型的0.0
如下图所示:
同样整数数据也会转换为double类型
如下图所示:
所以,mybatis在判断的时候,数字0和空字符串是相等的,而我们的if判断里,是两者不相等时该条件才会起作用。
因此,在使用mybatis判断的时候,一定要注意类型是否一致,数字类型就不要判断空字符串的情况了。
感谢你能够认真阅读完这篇文章,希望小编分享的"mybatis中的test语句失效怎么办"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
类型
时候
语句
引号
数据
篇文章
情况
条件
空字符
怎么办
一致
作用
字符
数字
问题
业务
事项
价值
兴趣
功能
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
游戏挂云端哪个服务器快
成都企业软件开发报价
全球网络技术峰会
昆山市企业erp软件开发
软件开发人月计算
姑苏区金利达网络技术服务部
照片上传统计软件开发
云服务器和共享主机
武汉软件开发驻场服务方案
造成数据库的安全性问题
郑州服务器租赁
汶川县非物质文化遗产数据库
数据库连接池等待统计
贵阳租服务器
杭州武夷山软件开发
软件开发信息安全的需求
橙荃互联网科技有限公司做什么的
golang软件开发工程师
服务器需要多少电源
回家如何解释网络安全工作
数据库怎么在表中查到重复数据
高中会试 计算机网络技术应用
网络安全普及知识答题
网络技术课程思政
图从数据库到知识图谱
安阳学习软件开发
服务器 内存大小
1u服务器 深度
邮件服务器正常是指客人还是商家
判断软件开发好坏的指标