中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用MyBatis時常見的錯誤有哪些

發布時間:2020-11-18 16:15:24 來源:億速云 閱讀:178 作者:Leah 欄目:開發技術

這篇文章給大家介紹使用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','x','d','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>

關于使用MyBatis時常見的錯誤有哪些就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

马关县| 新邵县| 府谷县| 和政县| 西乡县| 蚌埠市| 高平市| 江安县| 庆元县| 云阳县| 葫芦岛市| 禄丰县| 临海市| 河西区| 三门峡市| 乌审旗| 肇东市| 荆门市| 凤冈县| 吴旗县| 和平区| 麦盖提县| 平谷区| 武强县| 浮山县| 汾西县| 皋兰县| 尉犁县| 子洲县| 景德镇市| 洪湖市| 辽中县| 灵山县| 建平县| 江油市| 荥阳市| 文化| 和平县| 瓦房店市| 金秀| 尉氏县|