mybatisplus出现There is no getter for property named ‘orderDate‘ in ‘class java.lang.String‘

这是因为mybatis对parameterType="String的SQL语句做了限制

解决方案1:加入@Param注解

@Mapper
public interface YourMapper {
    Integer insert(@Param("username") String username,
                   @Param("address") String address);
}

@Param注解的使用场景:

1.方法有多个参数,需要@Param注解

@Mapper
public interface objectMapper {
    Integer insert(@Param("username") String username,
                   @Param("password") String password);
}

2.方法参数要取别名,需要 @Param 注解,和xml文件的名称一致

@Mapper
public interface objectMapper {
    User objectMapper (@Param("name") String username);
}
//对应mapper
<select id="getUserByUsername" parameterType="org.javaboy.helloboot.bean.User">
    select * from user where username=#{name};
</select>

3.XML 中的 SQL 使用了 $ ,那么参数中也需要 @Param 注解

@Mapper
public interface UserMapper {
    List<User> getAllUsers(@Param("order_by")String order_by);
}
//对应mapper的xml
<select id="getAllUsers" resultType="org.javaboy.helloboot.bean.User">
    select * from user
    <if test="order_by!=null and order_by!=''">
        order by ${order_by} desc
    </if>
</select>

4.那就是动态 SQL ,如果在动态 SQL 中使用了参数作为变量,那么也需要 @Param 注解,即使你只有一个参数。

@Mapper
public interface UserMapper {
    List<User> getUserById(@Param("id")Integer id);
}
//对应xml文件

<select id="getUserById" resultType="org.javaboy.helloboot.bean.User">
    select * from user
    <if test="id!=null">
        where id=#{id}
    </if>
</select>

其他注意事项:

首先,请确保你的实体类中包含了名为 'orderDate' 的正确属性,并且具有相应的 getter 方法。getter 方法的命名应该遵循 JavaBean 的规范,例如 getOrderDate()

如果你已经正确定义了属性和对应的 getter 方法,但仍然出现该错误,那可能是由于 MyBatis Plus 自动填充功能导致的。MyBatis Plus 提供了自动填充功能,它会在插入或更新实体时自动设置被标注的属性的值。

此错误通常是因为配置了自动填充功能,但没有正确设置填充的属性和类型。

你可以检查以下几点:

  1. 确保实体类中的属性和数据库表中的字段一致,并且有对应的 getter 和 setter 方法。

  2. 检查是否在实体类的属性上使用了 MyBatis Plus 的注解 @TableField(fill = FieldFill.XXX) 来表示自动填充属性。在这种情况下,确认填充属性的类型与实际类型一致。

  3. 如果不需要自动填充功能,可以考虑删除相关的注解或禁用自动填充功能。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
这个问题看起来是在尝试访问JavaString类中的一个属性(名为"month"),但是JavaString类中并没有这个属性。在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",并且我们通过分割字符串的方式提取出月份部分。这种方法对于一些常见日期格式应该是有效的,但并不是所有的日期字符串都可以这样解析。对于更复杂的日期格式,你可能需要使用更复杂的解析逻辑。 如果你的需求是在特定的环境下,例如你在使用某种特定框架或者库,并且有获取月份的方法,那么请提供更多的信息,我将很高兴为你提供更具体的帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值