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

网友投稿 249 2023-02-21

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

这是一个出错的代码

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文件,没错,如下:

SELECT DISTINCT

order_info.id,

user_info.user_name,

order_info.order_status,

order_info.pay_type,

order_info.total_price,

ship_address.ship_user_name,

ship_address.ship_user_mobile,

ship_address.ship_address,

order_goods.goods_desc,

order_goods.goods_sku,

order_goods.goods_icon,

order_goods.goods_price

FROM

order_info,

user_info,

ship_address,

order_goods

WHERE

order_info.id = order_goods.oikTSxrder_id

AND order_info.user_id = user_info.id

AND order_info.ship_id = ship_address.id

AND order_info.id = #{id}

检查mapper接口,如下:

public interface OrderInfoManageMapper {

List selectAllOrder();

void modifyDelivery(int id);

void removeOrder(int id);

List selectOrdeikTSxrById(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})

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Springboot+MybatisPlus+Oracle实现主键自增的示例代码
下一篇:通过openOffice将office文件转成pdf
相关文章

 发表评论

暂时没有评论,来抢沙发吧~