什么时候使用resulttype_resultmap和resulttype的一些使用误区

本文探讨了MyBatis中resultType和resultMap的区别。当使用resultType时,MyBatis会将查询结果直接映射到指定类型的对象。而resultMap允许更复杂的映射,如处理一对一、一对多的关系。不正确地使用resultType可能导致错误,此时需确保类的别名已正确配置。理解并恰当运用这两个配置能更好地进行数据映射。
摘要由CSDN通过智能技术生成

mybatis的映射配置文件中的两个返回值类型resultmap和resulttype;

直接来测试代码:

select id,username,userpwd from t_users where id=#{id}

这是正确的,resulttype在这里是类的全类名,这样执行没有任何问题;

fe342dbd9d4e7bb89fcd33a7a12d9e33.png

结果就是我们想要的。

接下来我们来定义一个:

然后我们修改一下上面的配置:

select id,username,userpwd from t_users where id=#{id}

我们把resulttype改成resultmap然后取了中的id;运行结果也是正常的;跟上面打印的是一样的;

接下来看一下他们之间的不同点:

7550498fde432c1d66845ebb75108f13.png

当看到这种错误的时候,就说明用的resulttype指定到中的id上去了;

select id,username,userpwd from t_users where id=#{id}

想让上面的配置起作用该怎么改?那就是使用别名:在mybatis-config.xml中加入

这里的alias就是resulttype的值;

以上只是我们书写时容易注意不到的部分;

注意:mybatis返回的类型:那一定是map类型了,就是键值对的形式返回数据;但是我们使用resulttype时,会把map中的值取出来赋值给对象的属性;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值