orgapachibatis.reflectionReflectionExceptionThere is no getter for property named userId in javalang

学习博客:https://www.cnblogs.com/mengw/p/12622071.html

使用mybatis的动态sql进行一个条件的查询操作,mapper.xml的SQL语句如下

controller.java

在浏览器上进行测试,报出如下错误

      

解决

     把mapper.xml中的动态sql中的<if></if>标签中的判空的参数由 userId改为_parameter

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.atguigu.dao.UserDao">
    <select id="queryById" parameterType="int" resultType="com.atguigu.entity.UserEntity">
        select * from user
        <where>
            <if test="_parameter!=null"> //由userId改为_parameter
                id=#{userId}
            </if>
        </where>
    </select>
</mapper>

重新启动运行

原因

              在使用mybatis的动态sql进行单一条件的判断时,如果传入的sql的参数 不是实体或者map,如果把入参的参数写成入参(SQL查询条件)的名称,那么就会报org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'userId' in 'class java.lang.Integer'的错误,如果单个入参,使用if做判断的,mybatis内置了对单一对象的判断参数名称_parameter,所以如果单一条件下如果传入的不是map类型的或者实体类型的,那么就使用_parameter做为判断条件

 

这个问题看起来是在尝试访问Java的String类中的一个属性(名为"month"),但是Java的String类中并没有这个属性。在Java中,String类没有提供名为"month"的属性或方法。如果你想获取月份,你可能需要使用java.time包中的LocalDate类或者使用循环或其他方式手动提取出日期字符串中的月份信息。 如果你的目的是从某个特定格式的日期字符串中提取月份,那么你可以通过编程的方式手动解析出这个信息。下面是一个基本的例子: ```java public class DateParser { public static void main(String[] args) { String dateString = "your_date_string"; int month = extractMonth(dateString); System.out.println("Month: " + month); } public static int extractMonth(String dateString) { String[] parts = dateString.split("/"); // 假设日期格式为"day/month/year" return Integer.parseInt(parts); // 返回月份部分 } } ``` 在这个例子中,我们假设日期字符串的格式是"day/month/year",并且我们通过分割字符串的方式提取出月份部分。这种方法对于一些常见日期格式应该是有效的,但并不是所有的日期字符串都可以这样解析。对于更复杂的日期格式,你可能需要使用更复杂的解析逻辑。 如果你的需求是在特定的环境下,例如你在使用某种特定框架或者库,并且有获取月份的方法,那么请提供更多的信息,我将很高兴为你提供更具体的帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值