首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

ibatis实战以内联结果映射

2012-11-08 
ibatis实战之内联结果映射ibatis实战之内联结果映射----------?面blog,我们给出的示例中都没有定义任何结

ibatis实战之内联结果映射

ibatis实战之内联结果映射

----------

?

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

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

?

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

?

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

List list = sqlMap.queryForList("Account.getAllAccountIdValues",null);
?该已映射语句返回Account表中所有的accountId值,作为简单的Integer对象的List。

?

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

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

?

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

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

?

?

?


?

热点排行