gpt4 book ai didi

java - 对不同的列名重复使用 resultMap

转载 作者:行者123 更新时间:2023-12-02 00:56:09 25 4
gpt4 key购买 nike

有没有办法在单个查询中多次重用同一个 resultMap。

例如,假设我有一个“foo”结果映射:

<resultMap id="foo" class="Foo">
<result property="Bar" column="bar" />
</resultMap>

有没有办法定义另一个 resultMap 来对不同的列重用上述内容?类似...

<resultMap id="fizz"class="Fizz">
<result property="Foo1" column="bar=bar1" resultMapping="foo" />
<result property="Foo2" column="bar=bar2" resultMapping="foo" />
<result property="Foo3" column="bar=bar3" resultMapping="foo" />
</resultMap>

最佳答案

差不多了。如果您在查询中选择 Foo 的 ID,则可以让 Fizz 结果映射针对该 ID 执行 SELECT,这将使用 Foo 结果映射。

<result property="Foo1" column="bar1Id" select="selectFoo"/>

(假设您定义了 selectFoo 查询。)但是对于大型结果集来说,这非常慢,因为它对每一行执行额外的 SELECT。

iBATIS 针对典型情况提供了解决此问题的方法,在这种情况下,您有一个包含各种其他对象的复合对象。首先,定义一个连接表的查询,然后可以使用 fooMap填充 Foo :

<result property="Foo1" resultMap="fooMap"/>

但是您不能将结果映射两次用于两个不同的 Foos因为结果映射指定了某些列名称。不过,您可以使用另一种技术:

<result property="foo1.bar" column="foo1bar"/>
<result property="foo2.bar" column="foo2bar"/>

更多详细信息请参见 iBatis Datamapper 手册第 35 页。

关于java - 对不同的列名重复使用 resultMap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/205182/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com