当前位置: 首页 > 编程笔记 >

MyBatis 参数类型为String时常见问题及解决方法

卫才哲
2023-03-14
本文向大家介绍MyBatis 参数类型为String时常见问题及解决方法,包括了MyBatis 参数类型为String时常见问题及解决方法的使用技巧和注意事项,需要的朋友参考一下

1. 参数为String时的插值问题

假设有下面一Dao接口方法

public Account findByAccountType (String type)throws DaoException;

对应的Mapper.xml

<select id="findByAccountType " parameterType="string" resultType="account">
  select *
  form account
  <where>
    <if test ="type != null">
      type=#{type}
    </if>
  </where>
</select>

一般我们都是按这样的方式来写的,对于其他类型是没错的,但是如果为String的话会抛下面的异常:

There is no getter for property named 'type ' in 'class java.lang.String'

因为MyBatis要求如果参数为String的话,不管接口方法的形参是什么,在Mapper.xml中引用时需要改变为_parameter才能识别 :

<select id="findByAccountType " parameterType="string" resultType="account">
  select *
  form account
  <where>
    <if test ="_parameter!= null">
      type=#{_parameter}
    </if>
  </where>
</select>

2. 对字符串参数进行是否相等 比较时的问题

错误:

<if test="_parameter == '1' ">
  type=#{_parameter}
</if>

正确:

<if test='_parameter == "1" '>
  type=#{_parameter}
</if>
<if test="_parameter == '1'.toString() ">
  type=#{_parameter}
</if>

注:上述问题不仅限于<if>标签,其他动态sql标签在对String进行处理时也会出现同样的问题。

以上所述是小编给大家介绍的MyBatis 参数类型为String时常见问题及解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!

 类似资料:
  • 不太会使用 Env 工具的请先看一遍 《Env 用户手册》(不长的,看完费不了几分钟) 提示 Env 工具和 源码 所处的目录都不能有中文或空格请先检查!! code 是一个命令 点 ‘.’ 是一个参数表示当前目录,中间有一个空格。 romfs ramfs 文件系统中的文件名和c的变量的命名一样,只能由英文字母开头且仅包含数字和下划线。 修改 qemu.bat 里面的参数时,要注意那是一行参数中间

  • 解决方案常见问题 Windows Needing to re-target the Windows SDK XCode XCode PNG Compression issue It is possible that your PNG images contain incorrect color profiles. You can convert color profiles using Image

  • 本文向大家介绍DevExpress TreeList 常见问题解决方法,包括了DevExpress TreeList 常见问题解决方法的使用技巧和注意事项,需要的朋友参考一下 1、 如何给节点添加图片? 首先需要添加一个图片控件,然后给它加入图片,最后把TreeList的节点图片属性和图片控件绑定,代码如下: 2、 如何将背景色设为透明? 3、 如何展开当前节点和父节点? 4、 如何设置显示水平滚

  • 本文向大家介绍tensorflow-gpu安装的常见问题及解决方案,包括了tensorflow-gpu安装的常见问题及解决方案的使用技巧和注意事项,需要的朋友参考一下 装tensorflow-gpu的时候经常遇到问题,自己装过几次,经常遇到相同或者类似的问题,所以打算记录一下,也希望对其他人有所帮助 基本信息 tensorflow-gpu pip安装(virtualenv等虚拟安装实质也是pip安

  • 本文向大家介绍Java 创建URL的常见问题及解决方案,包括了Java 创建URL的常见问题及解决方案的使用技巧和注意事项,需要的朋友参考一下 URL无处不在,不过似乎开发人员并没有真正地理解它们,因为我在Stack Overflow上经常看到有人在问如何正确的创建一个URL。想知道URL语法是如何工作的,可以看下Lunatech的 这篇文章 ,非常不错 。 本文不会深入介绍URL的全部语法(如果

  • 如何组织我的应用程序? There is no definitive answer to this question. The answer depends on the scale of your application and the team that is involved. To be as flexible as possible, Express makes no assumptio