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

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

 更新時間:2020年11月17日 10:52:18   作者:龍谷情Sinoam  
這篇文章主要介紹了MyBatis常見報錯問題及解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(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>

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

相關(guān)文章

  • Java8 Stream API 詳細使用方法與操作技巧指南

    Java8 Stream API 詳細使用方法與操作技巧指南

    這篇文章主要介紹了Java8 Stream API 詳細使用方法與操作技巧,總結(jié)分析了Java8 Stream API 基本功能、使用方法與操作注意事項,需要的朋友可以參考下
    2020-05-05
  • log4j2的異步使用及添加自定義參數(shù)方式

    log4j2的異步使用及添加自定義參數(shù)方式

    這篇文章主要介紹了log4j2的異步使用及添加自定義參數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • springboot項目中實現(xiàn)訪問druid內(nèi)置監(jiān)控頁面

    springboot項目中實現(xiàn)訪問druid內(nèi)置監(jiān)控頁面

    這篇文章主要介紹了springboot項目中實現(xiàn)訪問druid內(nèi)置監(jiān)控頁面的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java多線程與線程池技術(shù)分享

    Java多線程與線程池技術(shù)分享

    這篇文章主要介紹了Java多線程與線程池技術(shù)分享,線程池本質(zhì)是池化技術(shù)的應(yīng)用,和連接池類似,創(chuàng)建連接與關(guān)閉連接屬于耗時操作,下文相關(guān)介紹需要的小伙伴可以參考一下
    2022-03-03
  • JVM之內(nèi)存分配和回收機制

    JVM之內(nèi)存分配和回收機制

    本篇主要介紹JVM內(nèi)存分配和回收策略,內(nèi)容主要節(jié)選自《深入理解java虛擬機》,需要的朋友可以參考下
    2023-05-05
  • Maven默認中央倉庫(settings.xml 配置詳解)

    Maven默認中央倉庫(settings.xml 配置詳解)

    這篇文章主要介紹了Maven默認中央倉庫(settings.xml 配置詳解),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • mybatisplus邏輯刪除基本實現(xiàn)和坑點解決

    mybatisplus邏輯刪除基本實現(xiàn)和坑點解決

    這篇文章主要介紹了mybatisplus邏輯刪除基本實現(xiàn)和坑點解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • springboot+rabbitmq實現(xiàn)指定消費者才能消費的方法

    springboot+rabbitmq實現(xiàn)指定消費者才能消費的方法

    當項目部署到測試環(huán)境后,QA測試過程中,總是“莫名其妙”的發(fā)現(xiàn)所保存的用戶付款單數(shù)據(jù)有問題。這篇文章主要介紹了springboot+rabbitmq實現(xiàn)指定消費者才能消費,需要的朋友可以參考下
    2021-11-11
  • Java的NIO與IO的詳解及對比

    Java的NIO與IO的詳解及對比

    這篇文章主要介紹了Java的NIO與IO的詳解及對比的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • druid升級后sql監(jiān)控頁面為空白的解決

    druid升級后sql監(jiān)控頁面為空白的解決

    這篇文章主要介紹了druid升級后sql監(jiān)控頁面為空白的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06

最新評論