欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MyBatis常见报错问题及解决方案

程序员文章站 2022-03-18 16:37:32
这是一个出错的代码一、报错:1 there is no getter for property named 'id' in 'class java.lang.integer'检查mapper.xml文...

这是一个出错的代码

一、报错:

1 there is no getter for property named 'id' in 'class java.lang.integer'

检查mapper.xml文件,没错,如下:

检查mapper接口,如下:

看似没有问题,但是id的话,需要这么写(看最后一行):

二、sql没问题却报错:

java.sql.sqlexception: 无效的列类型: 1111

原因是在mybatis中

param是java传来的字符串 'id1','id2','id3'

此时就会报这个错误,因为使用in条件时不能用#,要使用$,如

三、java想mybatis中传入‘a','b','c',放在in中

可能会这么写mybatis:

 select * from table_name
 where 1=1
 <if para!= null && para!="" >
 and pars in (#{para})
 </if>

java传过来的para为

 string para = "'a','x','d','g'";

此时预期效果为

 select * from table_name
 where 1=1
 and pars in ('a','x','d','g')

但是判断会通过,值不会传入,会出现:

 select * from table_name
 where 1=1
 and pars in ()

将#换成$才可以。虽然#很安全

select * from table_name
where 1=1
<if para!=null && para!="" >
and pars in (${para})
</if>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。