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(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 詳細(xì)使用方法與操作技巧指南
這篇文章主要介紹了Java8 Stream API 詳細(xì)使用方法與操作技巧,總結(jié)分析了Java8 Stream API 基本功能、使用方法與操作注意事項,需要的朋友可以參考下2020-05-05
springboot項目中實現(xiàn)訪問druid內(nèi)置監(jiān)控頁面
這篇文章主要介紹了springboot項目中實現(xiàn)訪問druid內(nèi)置監(jiān)控頁面的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
Maven默認(rèn)中央倉庫(settings.xml 配置詳解)
這篇文章主要介紹了Maven默認(rèn)中央倉庫(settings.xml 配置詳解),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-12-12
mybatisplus邏輯刪除基本實現(xiàn)和坑點解決
這篇文章主要介紹了mybatisplus邏輯刪除基本實現(xiàn)和坑點解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
springboot+rabbitmq實現(xiàn)指定消費者才能消費的方法
當(dāng)項目部署到測試環(huán)境后,QA測試過程中,總是“莫名其妙”的發(fā)現(xiàn)所保存的用戶付款單數(shù)據(jù)有問題。這篇文章主要介紹了springboot+rabbitmq實現(xiàn)指定消費者才能消費,需要的朋友可以參考下2021-11-11

