SQLAlchemy-当count()表示还有更多结果时,仅返回一个结果

SQLAlchemy-当count()表示还有更多结果时,仅返回一个结果,第1张

SQLAlchemy-当count()表示还有更多结果时,仅返回一个结果

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
当要求返回完整实体时,所有这些冗余身份将唯一化,直到每一行所代表的单个对象。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5631565.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-15
下一篇2022-12-16

发表评论

登录后才能评论

评论列表(0条)

    保存