有谁知道如何按距搜索位置的距离对 Facebook 位置进行排序?请注意,我不想在我的客户端应用程序中订购结果。我希望 Facebook 服务器为我提供有序的结果以方便分页。我总是想将后续查询中的位置附加到数组的末尾。
这似乎不可能使用图形 API 查询,例如:
https://graph.facebook.com/search?q=coffee&type=place¢er=37.76,-122.427&distance=1000& ....因为没有办法告诉 Facebook 订购结果。最近的地方可能在返回结果列表的最后。
我一直在尝试使用 FQL
复制上述查询,但有一个问题,因为 Facebook 地点表中的名称和描述字段不可索引。 FQL 例如:
SELECT
page_id, name, display_subtext, description,
distance(latitude, longitude, "37.76", "-122.427"), checkin_count
FROM place
WHERE ((distance(latitude, longitude, "37.76", "-122.427") < 25000)
AND (strpos(lower(name), "coffee") >= 0
OR strpos(lower(description), "coffee") >= 0))
ORDER BY distance(latitude, longitude, "37.76", "-122.427") ASC
LIMIT 20 OFFSET 0
问题在于字段 name
和 description
在 place 表中不可索引。这意味着并非所有结果都由 FQL 返回,有很多结果缺失。
最佳答案
似乎可以使用此 FQL。 contains
函数似乎与 q=
Graph API 参数一样工作。这是您使用 contains
SELECT page_id, name, description, latitude, longitude, checkin_count, distance(latitude, longitude, "37.76", "-122.427")
FROM place
WHERE distance(latitude, longitude, "37.76", "-122.427") < 1000
AND CONTAINS("coffee")
ORDER BY distance(latitude, longitude, "37.76", "-122.427")
LIMIT 20
关于facebook - 按距离排序 Facebook Places 结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8166500/