将所有python

将所有python,第1张

将所有python

您提供的代码有两个问题,这些问题解释了为什么获得结果。

第一个问题是您的查询

test.query.filter(url='.').all()
返回一个空列表。这将仅由于您没有与指定过滤器一起使用的有效索引而返回空列表。您确实有该列的2个索引-
唯一索引(用于按精确字符串查找url)和后缀索引(用于查找以特定字符串结尾的url)-但都不能提供按内容进行过滤的功能在关系世界中,存在一个“喜欢”查询。前缀索引(使用创建的索引
prefix=True
)可以让您使用
test.query.like(url='*.')
,但这会非常慢(它执行索引扫描而不是直接查找[1])。

为了帮助防止出现与索引/查询相关的问题,当用户尝试通过不存在的索引过滤数据时,我添加了QueryError异常。今晚晚些时候,我将通过这些更改发布0.31.4。

您遇到的第二个错误(是导致异常的原因)是您在

.count()
没有参数的情况下进行调用。在
h.count()
调用时
type(h) ==list
,和和Python列表对象需要一个参数来对等于列表中提供的参数的值进行计数。如果跳过
.all()
原始查询的一部分,则会返回一个查询对象。该查询对象具有一个
.count()
方法,并将返回匹配结果的计数。

[1]并非rom中的所有“喜欢”查询都很慢,但是快速的查询需要非通配符前缀以限制要扫描/过滤的数据范围。



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

原文地址: http://outofmemory.cn/zaji/4912223.html

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

发表评论

登录后才能评论

评论列表(0条)

保存