MyBatis常見(jiàn)報(bào)錯(cuò)問(wèn)題及解決方案
這是一個(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)文章
Java8 Stream API 詳細(xì)使用方法與操作技巧指南
這篇文章主要介紹了Java8 Stream API 詳細(xì)使用方法與操作技巧,總結(jié)分析了Java8 Stream API 基本功能、使用方法與操作注意事項(xiàng),需要的朋友可以參考下2020-05-05springboot項(xiàng)目中實(shí)現(xiàn)訪(fǎng)問(wèn)druid內(nèi)置監(jiān)控頁(yè)面
這篇文章主要介紹了springboot項(xiàng)目中實(shí)現(xiàn)訪(fǎng)問(wèn)druid內(nèi)置監(jiān)控頁(yè)面的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06Java多線(xiàn)程與線(xiàn)程池技術(shù)分享
這篇文章主要介紹了Java多線(xiàn)程與線(xiàn)程池技術(shù)分享,線(xiàn)程池本質(zhì)是池化技術(shù)的應(yīng)用,和連接池類(lèi)似,創(chuàng)建連接與關(guān)閉連接屬于耗時(shí)操作,下文相關(guān)介紹需要的小伙伴可以參考一下2022-03-03Maven默認(rèn)中央倉(cāng)庫(kù)(settings.xml 配置詳解)
這篇文章主要介紹了Maven默認(rèn)中央倉(cāng)庫(kù)(settings.xml 配置詳解),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12mybatisplus邏輯刪除基本實(shí)現(xiàn)和坑點(diǎn)解決
這篇文章主要介紹了mybatisplus邏輯刪除基本實(shí)現(xiàn)和坑點(diǎn)解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03springboot+rabbitmq實(shí)現(xiàn)指定消費(fèi)者才能消費(fèi)的方法
當(dāng)項(xiàng)目部署到測(cè)試環(huán)境后,QA測(cè)試過(guò)程中,總是“莫名其妙”的發(fā)現(xiàn)所保存的用戶(hù)付款單數(shù)據(jù)有問(wèn)題。這篇文章主要介紹了springboot+rabbitmq實(shí)現(xiàn)指定消費(fèi)者才能消費(fèi),需要的朋友可以參考下2021-11-11druid升級(jí)后sql監(jiān)控頁(yè)面為空白的解決
這篇文章主要介紹了druid升級(jí)后sql監(jiān)控頁(yè)面為空白的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06