国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

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

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

這是一個出錯的代碼

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 国产精品视频免费 | 国产成人在线视频网站 | 国产一区二区免费在线观看 | 一区二区三区欧美日韩国产 | 久久视频在线观看免费 | 97超频国产在线公开免费视频 | 久久综合丁香 | 亚洲国产精品综合欧美 | 正在播放的国产a一片 | 在线观看偷拍视频一区 | 亚洲日本视频在线 | 国产精品变态重口在线 | 欧美视频一区二区三区四区 | 国产高清免费不卡观看 | 日本在线视频免费看 | 色欧美在线 | 国产精品露脸脏话对白 | 男人天堂网在线视频 | 在线观看一级毛片 | 美女福利视频午夜在线 | 国产成人精品午夜免费 | 日本一区二区三区欧美在线观看 | 国产超清在线观看 | 99精品视频在线观看免费 | 香蕉久久成人网 | 女人张开腿让男人桶视频 | 国产高清在线视频 | 亚洲精品国产成人 | 免费视频网站一级人爱视频 | 欧美成人 综合网播九公社 欧美成人26uuu欧美毛片 | 三级毛片网 | 看三级毛片 | 最刺激黄a大片免费观看下截 | 国产乱肥老妇精品视频 | 在线观看91精品国产入口 | 日韩在线一区二区三区视频 | 手机看片国产免费永久 | 男女猛烈无遮掩免费视频 | 久久综合婷婷香五月 | 波多野在线视频 | 免费国产成人高清无线看软件 |