1. 程式人生 > 程式設計 >MyBatis常見報錯問題及解決方案

MyBatis常見報錯問題及解決方案

這是一個出錯的程式碼

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','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'";

此時預期效果為

SELECT * FROM TABLE_NAME
WHERE 1=1
AND PARS in ('a','g')

但是判斷會通過,值不會傳入,會出現:

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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。