色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:83日期:2023-10-21 16:22:52

這是一個(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 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_NAMEWHERE 1=1<if para!=null && para!='' >AND PARS in (${para})</if>

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

相關(guān)文章:
主站蜘蛛池模板: 久久91综合国产91久久精品 | 亚洲视频一区二区在线观看 | 99热在线观看 | 狠狠色丁香婷婷综合小时婷婷 | 欧美日韩国产免费一区二区三区 | 久草欧美 | 亚洲精品国产三级在线观看 | 免费观看欧美一级毛片 | 亚洲欧美一区二区久久香蕉 | 日本aa毛片a级毛片免费观看 | 久久网免费视频 | 艳女伦交一级毛片 | 国产片一级 | 欧美人禽杂交狂配毛片 | 午夜两性视频 | 一级香蕉免费毛片 | 国产一级毛片网站 | 欧美日韩不卡一区 | 九九99re在线视频精品免费 | 国产欧美va欧美va香蕉在线 | 精品国产1区 | 黄频漫画 | 成人免费午间影院在线观看 | 国产精品yjizz视频网一二区 | 国产3区| 欧美一级大黄特黄毛片视频 | 亚洲第一中文字幕 | 黄色三级国产 | 国产精品中文字幕在线观看 | 国产成人精品综合久久久 | 日韩黄色免费观看 | 亚洲精品国产字幕久久不卡 | 精品国产看高清国产毛片 | 一级国产精品一级国产精品片 | 九九视频免费观看 | 99黄色网| 日韩在线观看视频网站 | 亚洲欧美日韩精品在线 | 欧美日韩精品一区二区视频在线观看 | 国产欧美久久久精品 | 久久久高清免费视频 |