Mapper method ‘xxx‘ attempted to return null from a method with a primitive return type (int)

文章讲述了在MyBatis中,由于Mapper方法返回类型设置为原始数据类型int,当查询结果为null时引发BindingException。解决办法是将返回类型改为包装类Integer,或者用特殊值表示可能的业务逻辑。
摘要由CSDN通过智能技术生成

报错情况:

Request processing failed; nested exception is org.apache.ibatis.binding.BindingException: Mapper method 'com.aqiuo.mapper.UserMapper.login attempted to return null from a method with a primitive return type (int).

报错原因:

 <select id="login" resultType="java.lang.Integer">
        select * from user where account = #{account} and password = #{password};
    </select>

  int login(@Param("account") String account,@Param("password") String password);

        这个异常的主要原因是 MyBatis 的 Mapper 方法返回了 null,但方法的返回类型是原始数据类型(primitive data type)int。在 Java 中,原始数据类型不能表示 null 值,这就导致了 BindingException 异常

解决方法:

  1. 修改 Mapper 方法的返回类型: 将原始数据类型 int 改为对应的包装类 Integer,这样就可以返回 null 了。例如:

    public Integer login(String username, String password);

    确保 Mapper 方法的返回类型是引用类型而不是原始数据类型。

  2. 处理 null 值的情况: 如果返回 null 表示某种情况,可以通过其他方式来表示,而不是直接返回 null。例如,可以返回一个特殊的整数值,表示登录失败,然后在业务逻辑中进行判断。这样,即便返回值是原始数据类型 int,也可以避免出现 null

    public int login(String username, String password) { // 这里的 -1 可以表示登录失败 // 具体的返回值可以根据业务需要定义 return -1; }

        根据实际情况选择适合你业务需求的方法。如果登录失败需要返回更多信息,建议使用包装类 Integer,因为它允许返回 null,而原始数据类型 int 不支持。如果只是简单表示成功或失败,你也可以使用特殊的返回值来表示。

 <select id="login" resultType="java.lang.Integer">
        select * from user where account = #{account} and password = #{password};
    </select>

Integer login(@Param("account") String account,@Param("password") String password);

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

五敷有你

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值