MyBatis常見(jiàn)報(bào)錯(cuò)問(wèn)題及解決方案
這是一個(gè)出錯(cuò)的代碼
public interface OrderInfoManageMapper { List<GetOrderInfoManageListReq> selectAllOrder(); void modifyDelivery(int id); void removeOrder(int id); List<GetOrderInfoManageListReq> selectOrderById(@Param('id') Integer id);}
一、報(bào)錯(cuò):
1 There is no getter for property named ’id’ in ’class java.lang.Integer’
檢查mapper.xml文件,沒(méi)錯(cuò),如下:
<select parameterType='java.lang.Integer' resultMap='BaseResultMap'> 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.order_id AND order_info.user_id = user_info.id AND order_info.ship_id = ship_address.id <if test='id!= null and id!= ’’ '> AND order_info.id = #{id} </if> </select>
檢查mapper接口,如下:
public interface OrderInfoManageMapper { List<GetOrderInfoManageListReq> selectAllOrder(); void modifyDelivery(int id); void removeOrder(int id); List<GetOrderInfoManageListReq> selectOrderById(Integer id);}
看似沒(méi)有問(wèn)題,但是id的話(huà),需要這么寫(xiě)(看最后一行):
public interface OrderInfoManageMapper { List<GetOrderInfoManageListReq> selectAllOrder(); void modifyDelivery(int id); void removeOrder(int id); List<GetOrderInfoManageListReq> selectOrderById(@Param('id') Integer id);}
二、sql沒(méi)問(wèn)題卻報(bào)錯(cuò):
java.sql.SQLException: 無(wú)效的列類(lèi)型: 1111
原因是在mybatis中
SELECT C_NAME1, C_NAME2 FROM MY_TABLE WHERE 1=1 AND ID IN ({#param})
param是java傳來(lái)的字符串 ’id1’,’id2’,’id3’
此時(shí)就會(huì)報(bào)這個(gè)錯(cuò)誤,因?yàn)槭褂胕n條件時(shí)不能用#,要使用$,如
SELECT C_NAME1, C_NAME2 FROM MY_TABLE WHERE 1=1 AND ID IN ({$param})
三、java想mybatis中傳入‘a(chǎn)’,’b’,’c’,放在in中
可能會(huì)這么寫(xiě)mybatis:
SELECT * FROM TABLE_NAME WHERE 1=1 <if para!= null && para!='' > AND PARS in (#{para}) </if>
java傳過(guò)來(lái)的para為
String para = '’a’,’x’,’d’,’g’';
此時(shí)預(yù)期效果為
SELECT * FROM TABLE_NAME WHERE 1=1 AND PARS in (’a’,’x’,’d’,’g’)
但是判斷會(huì)通過(guò),值不會(huì)傳入,會(huì)出現(xiàn):
SELECT * FROM TABLE_NAME WHERE 1=1 AND PARS in ()
將#換成$才可以。雖然#很安全
SELECT * FROM TABLE_NAMEWHERE 1=1<if para!=null && para!='' >AND PARS in (${para})</if>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. mysql8.0.20數(shù)據(jù)目錄遷移的方法2. mysql啟動(dòng)時(shí)報(bào)錯(cuò) ERROR! Manager of pid-file quit without3. MySQL中InnoDB和MyISAM類(lèi)型的差別4. 如何在SQL Server 2005中為安裝程序增加計(jì)數(shù)器注冊(cè)表項(xiàng)值5. 淺談SELECT?*會(huì)導(dǎo)致查詢(xún)效率低的原因6. Mybatis自關(guān)聯(lián)查詢(xún)一對(duì)多查詢(xún)的實(shí)現(xiàn)示例7. 講解SQL Server數(shù)據(jù)庫(kù)備份的多種方式8. sql server 災(zāi)難恢復(fù)9. ACCESS轉(zhuǎn)SQL數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能10. SQLite教程(五):索引和數(shù)據(jù)分析/清理
