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)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值