如何评估/解释 sphinxql 查询?

发布于 2024-12-08 04:17:54 字数 455 浏览 1 评论 0原文

假设我有一个名为“worldcities”的sphinx索引,具有以下字段/属性:

country_id#int attribute

city#文本字段

accent_city#文本字段

,并且我运行以下sphinxql查询:

SELECT * FROM worldcities WHERE country_id = 16 AND MATCH((@(city,accent_city) "New Yor*"))

sphinx如何评估查询?: 是不是先搜索所有记录,然后通过count_id过滤结果: “给我所有以‘New Yor’开头的结果并按country_id过滤它们”?

或者它是否首先按国家/地区 ID 进行过滤并通过结果进行搜索: “给我所有 countr_id = 16 的结果,然后在其中搜索”?

希望我说清楚了

Suppose i have a sphinx index named "worldcities" with the with the following fields / attributes:

country_id # int attribute

city # text field

accent_city # text field

and i run the following sphinxql query:

SELECT * FROM worldcities WHERE country_id = 16 AND MATCH((@(city,accent_city) "New Yor*"))

How does sphinx evaluates the query?:
Is it first searching through all the records and then filters the results by countr_id:
"give me all the results that start with 'New Yor' and the filter them by country_id"?

Or does it filter first by country id and the searches through the results:
"give me all the results that have countr_id = 16 then search in those"?

Hope i made myself clear

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

扮仙女 2024-12-15 04:17:54

“给我所有以‘New Yor’开头的结果,并按country_id过滤它们”

这一个。

首先运行全文查询。然后过滤器“排除”不需要的匹配项。

顺便说一句,您的查询缺少一些引号,应该是

MATCH('@(city,accent_city) "New Yor*"')

Match 函数接受一个字符串。

"give me all the results that start with 'New Yor' and the filter them by country_id"

this one.

The full-text queries runs first. Then the filters 'exclude' non required matches.

btw, your query is missing some quotes, should be

MATCH('@(city,accent_city) "New Yor*"')

Match function takes a string.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文