Query当要求对象迭代表示类似的实体的结果时,该对象
TestSet将根据对象标识对结果行进行唯一化,因此,如果查询要返回每行具有相同
TestSet主键的100行,则只会得到一个结果对象背部。此行为起源于的“渴望加入”功能
Query,在这种情况下,通常会收到许多结果行,每个结果行具有相同的主要身份,但也包含要填充到在每个主要身份上进行收集-
在这种非常常见的情况下,只需要一个主要身份实例即可。
然后让我们考虑一下
distinct()。假设您对4M个对象的查询返回了id = 1的1000行,id =
2的1000行等,等等
Query。limit (100)的查询命中了id = 1的前100行,取整,然后返回一个结果对象,因为它们都是id =
1。但是有了
distinct(),突然我们得到了100个具有不同标识的行,即“ id = 1”,“ id = 2”,“ id = 3”。
Query然后将这些行中的每行分配给
TestSet身份映射中的新对象,您将获得100行。
设置
echo='debug'您
Engine暂时将显示SQL被发射以及结果行回来。当看到许多结果行都具有相同的主键时,您就会知道,
Query当要求返回完整实体时,所有这些冗余身份将唯一化,直到每一行所代表的单个对象。



