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对象时,也有相似的问题:尽管你仍然可以得到数据,但是这些数据不会在你所期望的地方。
如果你想要一种更加稳健的数据映射方式,请使用外部的结果映射。
除了上述这两个潜在的问题之外,如果希望让框架帮你完成映射,并且不在意第一次执行映射时额外的开销,那么使用自动映射还是很方便的。