占位符导致org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 。。

Mybatis的配置文件中的代码

<select id="todoTotalCount" resultType="java.lang.Integer" parameterType="java.lang.String">
		SELECT COUNT(*) AS total_count
		FROM (
				 SELECT STATUS FROM `dj_honor_member_honor` WHERE org_id LIKE '${orgId}%'
				 UNION ALL
				 SELECT STATUS FROM `dj_honor_member_punishment` WHERE org_id LIKE '${orgId}%'
				 UNION ALL
				 SELECT STATUS FROM `dj_honor_org_honor` WHERE org_id LIKE '${orgId}%'
			 ) AS combined_tables
		WHERE STATUS = 1;
	</select>

控制台输出的报错原因:
org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'orgId' in 'class java.lang.String'

问题发现:

MyBatis 在解析结果映射时找不到 'orgId' 属性,而这个属性是在查询中作为参数传递的。报错可能是由于使用 ${orgId} 时 MyBatis 试图在 java.lang.String 类型上查找 'orgId' 属性,而这个属性实际上不存在。通过将 ${} 替换为 #{},MyBatis 将 orgId 视为参数,并能够正确地处理它,避免了错误。

占位符:

1、#{} 占位符: 是预编译的占位符,用于防止 SQL 注入。在使用 #{} 时,MyBatis 会使用预编译语句,并确保参数被正确地设置到 SQL 语句中。这样可以有效地防止 SQL 注入攻击。

2、${} 占位符: 是直接替换占位符,不进行预编译。使用${}时,参数的值会被直接拼接到 SQL 语句中。虽然 ${} 允许你动态地拼接 SQL 片段,但它也增加了 SQL 注入的风险。

解决方法:

${} 替换为 #{},使用 #{}占位符可以确保 MyBatis 能够正确地处理参数,并在运行时将参数传递给查询。这样,应该就不再出现 "There is no getter for property named 'orgId'" 的异常了。

<select id="todoTotalCount" resultType="java.lang.Integer" parameterType="java.lang.String">
    SELECT COUNT(*) AS total_count
    FROM (
        SELECT STATUS FROM `dj_honor_member_honor` WHERE org_id LIKE #{orgId} 
        UNION ALL
        SELECT STATUS FROM `dj_honor_member_punishment` WHERE org_id LIKE #{orgId} 
        UNION ALL
        SELECT STATUS FROM `dj_honor_org_honor` WHERE org_id LIKE #{orgId}
    ) AS combined_tables
    WHERE STATUS = 1;
</select>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值