Mybatis-There is no getter for property named 'XXX' in 'class java.lang.String'解决办法

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

      初学mybatis没几天,遇到的问题不少,学到的东西也不少,越来越感觉mybatis用着还是挺有意思的。话说今天遇到了一个异常,折腾了好久;在网上搜了两篇文章并顺利解决,现在讲两篇文章整理出来,留作备份。

      mysql文如下,传入参数为‘parentCategoryId’,运行报错为:There is no getter for property named 'parentCategoryId' in 'class java.lang.String

	<select id="selectCategoryList"  parameterType="java.lang.String" resultType="MstCategoryBean">
		SELECT
			category_id				AS	categoryId,
			category_name			AS	categoryName,
			view_orderby			AS	viewOrderby
		FROM
			mst_category
		WHERE
			del_flg =0
		<if test="parentCategoryId!=null  and parentCategoryId!=''">
		and
			parent_category_id = #{parentCategoryId}
		</if>
	</select>

 发现不能将参数设为bean里的名称,如果传入类型为String类型,则参数需统一修改为[_parameter],修改后的sql语句如下(不管你的参数是什么,都要改成"_parameter")

<select id="selectCategoryList" parametertype="java.lang.String" resulttype="MstCategoryBean">  
        SELECT  
            category_id             AS  categoryId,  
            category_name           AS  categoryName,  
            view_orderby            AS  viewOrderby  
        FROM  
            mst_category  
        WHERE  
            del_flg =0  
          
        and  
            parent_category_id = #{_parameter}  
          
    </select>  

 ==================华丽的分割线=============另外一篇===================

用mybatis查询时,传入一个字符串传参数,且进行判断时,会报

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

 错误写法:

<select id="queryAllParentModule" resultType="jobModule" parameterType="jobModule">  
select modulecode,  
       modulename,  
       modulevalue,  
       linkurl,  
       rank,  
       parentmodule=isnull(parentmodule,1),  
       moduledescription   
from job_module  
<where>           
          <choose>    
              <when test="moduleCode!=null and moduleCode!=''">modulecode = #{moduleCode}</when>    
              <when test="moduleCode==null or moduleCode==''">(parentmodule is null or len(parentmodule)&lt;=0)</when>  
          </choose>    
      </where>   
lt;/select>  

 需要修改成:

    <select id="queryModuleByCode" resultType="jobModule" parameterType="string">  
    select modulecode,  
           modulename,  
           modulevalue,  
           linkurl,  
           rank,  
           parentmodule=isnull(parentmodule,1),  
           moduledescription   
    from job_module  
    <where>           
              <choose>    
                  <when test="_parameter!=null and _parameter!=''">modulecode = #{_parameter}</when>    
                  <when test="_parameter==null or _parameter==''">(parentmodule is null or len(parentmodule)&lt;=0)</when>  
              </choose>    
          </where>   
    lt;/select>  

 不管你的参数是什么,都要改成"_parameter";

 

 

两篇文章原文出处:

http://blog.csdn.net/noku_ln10/article/details/7977976

http://txin0814.iteye.com/blog/1533645

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值