1

可能重复:
Google App Engine Geohashing

我正在尝试使用 AppEngine 存储具有纬度和经度参数的模型。一切似乎都很好,除非我尝试检索两个位置之间的所有用户。我这样做:

 String query = "select from " + TUser.class.getName();
 query += " WHERE ( iLatitude >= " + lat_min + " && iLatitude <= " + lat_max + ")";
 query += " && ( iLongitude >= " + lon_min + " && iLongitude <= " + lon_max + ")";
 List<TUser> obj = (List<TUser>)pm.newQuery(query).execute();

但是,正如 AppEngine 文档中所说,这会引发:

 java.lang.IllegalArgumentException: Only one inequality filter per query is supported.  Encountered both latitude and longitude

我正在尝试为此找到解决方法,但没有运气。使用坐标总是需要至少两个不等式。那怎么解决呢?有什么解决办法吗?或者有谁知道什么时候会在 AppEngine 中实现?

由于数据库有数十万用户,我无法仅按纬度过滤查询,然后使用 FOR 迭代结果以获得具有正确经度的结果。数据太多。

谢谢,

4

1 回答 1

0

您需要查看将图块编码为单个字符串的geohash 。
查看此博客以了解如何使用它。

于 2013-01-02T14:42:33.113 回答