欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis常見(jiàn)報(bào)錯(cuò)問(wèn)題及解決方案

 更新時(shí)間:2020年11月17日 10:52:18   作者:龍谷情Sinoam  
這篇文章主要介紹了MyBatis常見(jiàn)報(bào)錯(cuò)問(wèn)題及解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

這是一個(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 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);
}

看似沒(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_NAME
WHERE 1=1
<if para!=null && para!="" >
AND PARS in (${para})
</if>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論