这是一个出错的代码
public interface OrderInfoManageMapper {
List selectAllOrder();
void modifyDelivery(int id);
void removeOrder(int id);
List selectOrderById(@Param("id") Integer id);
}
一、报错:
1 There is no getter for property named 'id' in 'class java.lang.Integer'
检查mapper.xml文件,没错,如下:
检查mapper接口,如下:
public interface OrderInfoManageMapper {
List selectAllOrder();
void modifyDelivery(int id);
void removeOrder(int id);
List selectOrderById(Integer id);
}
看似没有问题,但是id的话,需要这么写(看最后一行):
public interface OrderInfoManageMapper {
List selectAllOrder();
void modifyDelivery(int id);
void removeOrder(int id);
List selectOrderById(@Param("id") Integer id);
}
二、sql没问题却报错:
java.sql.SQLException: 无效的列类型: 1111
原因是在mybatis中
SELECT
C_NAME1,
C_NAME2
FROM
MY_TABLE
WHERe
1=1
AND ID IN ({#param})
param是java传来的字符串 'id1','id2','id3'
此时就会报这个错误,因为使用in条件时不能用#,要使用$,如
SELECt
C_NAME1,
C_NAME2
FROM
MY_TABLE
WHERe
1=1
AND ID IN ({$param})
三、java想mybatis中传入‘a','b','c',放在in中
可能会这么写mybatis:
SELECt * FROM TABLE_NAME
WHERe 1=1
AND PARS in (#{para})
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
AND PARS in (${para})
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。



