There is no getter for property named 'code' in 'class java.lang.String'

MyBaits中调用sql语句,往里传参数的过程是:如果是基本类型,直接让sql中的变量去接收传进来的变量值;如果是引用的话,先new 一个入参类型的对象 obj,然后将传进来的参数对象交给这个obj,然后通过sql中的变量名反射得到相应的get方法对象,然后通过get方法对象获取值。

这是基本类型:

<select id="queryUserById" parameterType="int" resultType="com.dimples.dto.User">
		select * from user where id = #{id}
</select>


User user = sqlsession.selectOne("test.queryUserById", 1);

这是引用类型:

<select id="queryUserByName" parameterType="java.lang.String" resultType="com.dimples.dto.User">
		select * from user where name like '%${_parameter}%'
</select>


List<User> users = sqlsession.selectList("test.queryUserByName", "tom");

在这里如果我sql中的参数写成%${value}%,也是可以的,因为String中有getValue方法。如果瞎写如aaa,则会报错:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'aaa' in 'class java.lang.String'
	at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:73)

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值