There is no getter for property named ‘xxxxx’ in ‘class com.xxx.xx.xx.xxxx‘”,

原文链接:https://www.longkui.site/program/java/getter/5082/

0.背景
SpringMVC架构,使用mybatis执行insert语句,然后开始报错:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named ‘xxxxx’ in ‘class com.xxx.xxx.api.xxxx’”,

mapper层的写法:

void insertStudent(Student student);
xml层的写法:

insert into stu(id,name) values (#{id},#{name}) 然后就开始报上面的错误了。

1.问题原因及解法方法
实体类缺失getter/setter 方法。 解决办法,加入getter/setter方法
实体类名与数据库类名不符。这个一般遇不到,而且可以不一定要对应。
实体类名与 xml 中的 property 名不符, xml 中 column 名与 property 名不符。 解决办法: 这个如果你要做一一对应的话就写成一样的,要不然自己写参数对应也行。
编写 sql 语句不要多空格少逗号之类的,不要写错少些字母。解法办法:请仔细检查sql语句。
最后,就是我实际遇到的,mapper层和xml层写错了。

上面的mapper层代码应该改成下面这样:

void insertStudent(@Param(“student”) Student student);
xml层应该改成下面这样:

insert into stu(id,name) values (#{student.id},#{student.name}) PS: 不要过度依赖代码生成器,有的代码自己写两遍才知道问题所在。
这个问题看起来是在尝试访问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、付费专栏及课程。

余额充值