MyBatis常见报错问题及解决方案
这是一个出错的代码
publicinterfaceOrderInfoManageMapper{ ListselectAllOrder(); voidmodifyDelivery(intid); voidremoveOrder(intid); List selectOrderById(@Param("id")Integerid); }
一、报错:
1Thereisnogetterforpropertynamed'id'in'classjava.lang.Integer'
检查mapper.xml文件,没错,如下:
SELECTDISTINCT 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.order_id ANDorder_info.user_id=user_info.id ANDorder_info.ship_id=ship_address.id ANDorder_info.id=#{id}
检查mapper接口,如下:
publicinterfaceOrderInfoManageMapper{ ListselectAllOrder(); voidmodifyDelivery(intid); voidremoveOrder(intid); List selectOrderById(Integerid); }
看似没有问题,但是id的话,需要这么写(看最后一行):
publicinterfaceOrderInfoManageMapper{ ListselectAllOrder(); voidmodifyDelivery(intid); voidremoveOrder(intid); List selectOrderById(@Param("id")Integerid); }
二、sql没问题却报错:
java.sql.SQLException:无效的列类型:1111
原因是在mybatis中
SELECT C_NAME1, C_NAME2 FROM MY_TABLE WHERE 1=1 ANDIDIN({#param})
param是java传来的字符串'id1','id2','id3'
此时就会报这个错误,因为使用in条件时不能用#,要使用$,如
SELECT C_NAME1, C_NAME2 FROM MY_TABLE WHERE 1=1 ANDIDIN({$param})
三、java想mybatis中传入‘a','b','c',放在in中
可能会这么写mybatis:
SELECT*FROMTABLE_NAME
WHERE1=1
ANDPARSin(#{para})
java传过来的para为
Stringpara="'a','x','d','g'";
此时预期效果为
SELECT*FROMTABLE_NAME
WHERE1=1
ANDPARSin('a','x','d','g')
但是判断会通过,值不会传入,会出现:
SELECT*FROMTABLE_NAME
WHERE1=1
ANDPARSin()
将#换成$才可以。虽然#很安全
SELECT*FROMTABLE_NAME
WHERE1=1
ANDPARSin(${para})
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。