There is no getter for property named 'X' in 'class java.lang.XX'

UserDao.java代码如下:

package soc.dao;

import java.util.List;
import java.util.Map;

import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import soc.entity.User;

public interface UserDao {
	@Select("select * from user where id=#{id}")
	public User getUserById(@Param("id") Integer id);

	public List<User> query();
	
	public List<Map> querySection(Integer id);

}

userMapper.xml内容如下:

<?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="soc.dao.UserDao">
	<cache readOnly="true" eviction="FIFO" flushInterval="60000" />
	<resultMap id="BaseResultMap" type="soc.entity.User">
		<result column="id" property="id" />
		<result column="name" property="name" />
		<result column="salary" property="salary" />
		<result column="birthday" property="birthday" />
	</resultMap>
	<sql id="Base_Column_List">
		id,name,salary,birthday
	</sql>
	<select id="query" resultMap="BaseResultMap" useCache="true">
		select
		<include refid="Base_Column_List" />
		from user
	</select>
	<select id="querySection" resultType="map" parameterType="integer"
		useCache="true">
		select
		name,salary
		from user where
		<if test="id !=null"></if>
		id=#{id}
	</select>

</mapper>

结果运行querySection()后报错如下:

Mybatis There is no getter for property named 'id in 'class java.lang.Integer.

解决方法是:

1.在userMapper.xml中将<if test="id !=null"></if>去掉,即不加判断条件;

2.在userMapper.xml中将<if test="id !=null"></if>id=#{id}改为<if test="_parameter !=null"></if>id=#{_parameter}

3.仍然是<if test="id !=null"></if>id=#{id},但在userDao.java里将querySection(Integer id)方法改成querySection(@Param("id") Integer id).

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值