python - BadFilterError : invalid filter: Only one property per query may have inequality filters (<=, >=, <, >)

标签 python google-app-engine google-cloud-datastore

我正在尝试对两个不同的属性应用过滤器,但是 GAE 不允许我这样做那么解决方案是什么,这是代码片段:

if searchParentX :
    que.filter("parentX >=", searchParentX).filter("parentX <=", unicode(searchParentX) + u"\ufffd") 
    que.order('parentX')   

if searchParentY :
    que.filter("parentY >=", searchParentY).filter("parentY <=", unicode(searchParentY) + u"\ufffd") 

最佳答案

解决方案是进行内存过滤:

  1. 您可以运行两个查询(每个查询对一个属性进行过滤)并对结果进行交集(根据数据的大小,您可能需要限制一个查询的结果而不是另一个查询,以便它适合内存)
  2. 运行一个查询并过滤掉内存中的另一个属性(在这种情况下,如果您知道哪个属性会返回经过更多过滤的列表将会很有帮助)

或者,如果您的数据结构使您可以将数据分成多个集合,则可以对该集合执行等式过滤器并在内存中完成过滤。例如,如果您正在搜索字符串,但您知道字符串的长度是固定的(比如说 6 个字符),您可以创建一个包含 3/4 个字符的“查找”字段。然后当你需要搜索这个字段时,你通过匹配前几个字符来完成,并在内存中完成搜索。另一个例子:当搜索整数范围时,如果你可以定义范围的通用分组(比如一年的几十年,或价格范围),那么你可以定义一个“范围”字段来进行相等搜索并继续在内存中过滤

关于python - BadFilterError : invalid filter: Only one property per query may have inequality filters (<=, >=, <, >),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13391818/

相关文章:

google-cloud-datastore - Google App Engine 本地数据存储路径配置

google-app-engine - Golang GAE - mustache 结构中的 intID

python - 名字在字典中的出现次数

python - dev_appserver.py 打开一个文本文件,不部署

google-app-engine - AppEngine 数据存储 Golang : Get ancestor for a query result

google-app-engine - 将照片存储在 Blobstore 中或作为 Blob 存储在数据存储中 - 哪个更好/更高效/更便宜?

android - 解析从云端点返回的 JSON 错误(谷歌应用引擎)

python - 在 SQLAlchemy 中使用 bulk_update_mappings 更新具有不同值的多行

python - 在python中合并多个表后更改重复的列名

python - 为什么 Python 的导入不能像 C 的#include 那样工作?