您好,登錄后才能下訂單哦!
這篇文章給大家介紹使用MyBatis時常見的錯誤有哪些,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
這是一個出錯的代碼
public interface OrderInfoManageMapper { List<GetOrderInfoManageListReq> selectAllOrder(); void modifyDelivery(int id); void removeOrder(int id); List<GetOrderInfoManageListReq> selectOrderById(@Param("id") Integer id); }
一、報錯:
1 There is no getter for property named 'id' in 'class java.lang.Integer'
檢查mapper.xml文件,沒錯,如下:
<select id="selectOrderById" 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); }
看似沒有問題,但是id的話,需要這么寫(看最后一行):
public interface OrderInfoManageMapper { List<GetOrderInfoManageListReq> selectAllOrder(); void modifyDelivery(int id); void removeOrder(int id); List<GetOrderInfoManageListReq> 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(chǎn)','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'";
此時預(yù)期效果為
SELECT * FROM TABLE_NAME
WHERE 1=1
AND PARS in ('a','x','d','g')
但是判斷會通過,值不會傳入,會出現(xiàn):
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>
關(guān)于使用MyBatis時常見的錯誤有哪些就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。