这篇文章给大家介绍使用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','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>
关于使用MyBatis时常见的错误有哪些就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。