mybatis的映射配置文件中的两个返回值类型resultmap和resulttype;
直接来测试代码:
<select id="getUser" parameterType="string" resultType="pojo.User">
select id,username,userpwd from t_users where id=#{id}
</select>
这是正确的,resulttype在这里是类的全类名,这样执行没有任何问题;
结果就是我们想要的。
接下来我们来定义一个<resultMap>:
<resultMap id="user" type="pojo.User" >
<id column="id" property="id" />
<result column="username" property="username" />
<result column="userpwd" property="userpwd" />
</resultMap>
然后我们修改一下上面的配置:
<select id="getUser" parameterType="string" resultMap="user">
select id,username,userpwd from t_users where id=#{id}
</select>
我们把resulttype改成resultmap然后取了<resultMap>中的id;运行结果也是正常的;跟上面打印的是一样的;
接下来看一下他们之间的不同点:
当看到这种错误的时候,就说明用的resulttype指定到<resultMap>中的id上去了;
<select id="getUser" parameterType="string" resultType="user" >
select id,username,userpwd from t_users where id=#{id}
</select>
想让上面的配置起作用该怎么改?那就是使用别名:在mybatis-config.xml中加入
<typeAliases>
<typeAlias alias="user" type="pojo.User"/>
</typeAliases>
这里的alias就是resulttype的值;
以上只是我们书写时容易注意不到的部分;
注意:mybatis返回的类型:那一定是map类型了,就是键值对的形式返回数据;但是我们使用resulttype时,会把map中的值取出来赋值给对象的属性;