[英]Redisearch prefix search always returns max 200 for total for multiple fields index
使用 python RediSearch 客户端连接到 RediSearch 并执行应该匹配 300 个文档的前缀搜索,如果索引中有另一个 TagField,它只会返回 200:
from redisearch import Client, Query, TextField, TagField
client = Client('myindex')
client.create_index([TextField('username'), TagField('age')])
# add 300 documents
for i in range(300):
client.add_document(i, username='user%s' % i, age=i)
res = client.search(Query("@username:user*"))
assert res.total == 300 # this is always 200 no matter how many documents you add.
请参阅搜索查询语法:前缀匹配
关于前缀搜索的一些注意事项: 由于前缀可以扩展为许多术语,因此请谨慎使用它们。 没有魔法在进行,扩展将创建所有后缀的联合操作。
作为一种避免选择过多term的保护措施,并且block redis,它是单线程的,前缀匹配有两个限制:
前缀限制为 2 个或更多字母。 您可以使用模块命令行上的 MINPREFIX 设置更改此数字。
扩展限制为 200 个或更少。 您可以使用模块命令行上的 MAXEXPANSIONS 设置更改此数字。
有关如何配置,请参阅运行时配置:MAXEXPANSIONS 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.