时间:2021-05-20
这是一个出错的代码
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','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_NAME
WHERE 1=1
<if para!=null && para!="" >
AND PARS in (${para})
</if>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
微信小程序HTTPS报错常见问题及解决方案微信小程序开放公测已经一个多月了,因官方需求文档要求后台使用HTTPS请求进行网络通信,不满足条件的域名和协议无法请求
同时出现LNK2005和LNK1169error的解决办法项目场景:VisualStudioC++项目问题描述原因分析cpp引用cpp导致报错解决方案方案1:如
报错信息一:jQuery.handleErrorisnotafunction上传图片的时候,通过F12,查看到这个错误。解决方案:jquery版本问题,hand
就一直这样,卡在这儿,不动,也不报错,也没有报错日志。以下是我尝试的解决方案:扩展idea内存,无效。重启电脑,无效,似乎也不是网络的问题。切换本地仓库,无效。
我的idea版本2017.3.4,低版本貌似不会加上这个配置,idea高版本会补充知识:Mybatis传多个参数的问题及MyBatis报错Parameter'0