ibatis实战之内联结果映射

ibatis实战之内联结果映射

----------

 

面blog,我们给出的示例中都没有定义任何结果映射(result map),但确实定义了结果类(result class)。这种方式所以可行是因为ibatis的自动结果映射机制,该机制会在映射语句第一次被执行时,迅速地自动创建一个结果映射,然后将它应用于这条已映射语句。

可以有3种方式来使用这个特征:单列选择定多列选择动态多列选择

 

注意如果你既没有提供结果映射,也没有提供结果类,ibatis将执行你的语句但是却不返回任何东西

 

如果只想从某个查询中获取单列,就可以使用别名value作为一种快捷方式来完成此目的,这样就可以不需要定义复杂的结果映射了:

<select id="getAllAccountIdvalues" resultClass="int">
	select accountId as value from Account
</select>
List list = sqlMap.queryForList("Account.getAllAccountIdValues",null);
 该已映射语句返回Account表中所有的accountId值,作为简单的Integer对象的List。

 

如果需要查询多列,就可以使用自动结果映射来告诉ibatis将列名作为bean的属性名,或者作为Map键。(as别名呢?用了它就可以直接将别名作为bean的属性,或者Map的键???)

当以这种方式映射到bean时,需要牢记一点如果所选择的列在数据库中存在,但是不存在于你要映射的bean中 你将不会得到任何错误或警告,但是也得不到任何数据---这些数据只会静静地被忽略。映射到Map对象时,也有相似的问题:尽管你仍然可以得到数据,但是这些数据不会在你所期望的地方

 

如果你想要一种更加稳健的数据映射方式,请使用外部的结果映射

除了上述这两个潜在的问题之外,如果希望让框架帮你完成映射,并且不在意第一次执行映射时额外的开销,那么使用自动映射还是很方便的。

 

 

 


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值