- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用单个 API 调用获取用户所有 friend 的纬度/经度。我想我需要编写多查询 FQL 语句,但语法不正确。
我相信这两个查询需要如下所示:
'"friends":"SELECT uid,current_location FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = me())"'
'"location":"SELECT location FROM page WHERE id IN (SELECT current_location_id FROM #friends)"';
我的问题是,我需要以某种方式在第一个查询中获取 current_location 的 ID,以便我可以在第二个查询中引用它,但我只知道如何获取包含该 ID 的数组。
感谢您的帮助!
澄清:
我不是要让 friend 签到。相反,我想在地理 map 上绘制用户所有 friend 的“current_location”(即他们居住的地方)。我可以使用以下 FQL 查询获取用户的“current_location”:
"SELECT uid,sex,current_location FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = me())"
此查询返回以下数组:
[current_location] => Array
(
[city] => New York
[state] => New York
[country] => United States
[zip] =>
[id] => 108424279189115
[name] => New York, New York
)
其中不包含current_location(上例中的纽约)的经纬度
因此,我现在需要获取 current_location 的 ID(例如 108424279189115)并运行第二个 FQL 查询,例如:
"SELECT location,name FROM page WHERE page_id = 108424279189115)"
获取当前位置的经纬度。目前,我有一个运行第一个 FQL 查询的工作代码,然后在 php 中提取 page_id,然后运行第二个 FQL 查询以获取 current_location 纬度/经度。但是,出于性能原因,如果可能的话,我希望只运行一个多查询。
最佳答案
编辑:
查询应该通过将第二个查询调整为:
'"location":"SELECT location FROM page WHERE id IN (SELECT current_location.id FROM #friends)"';
在 FB API 中使用数组类型时,您可以通过执行 array.value 访问任何查询中的值
此外,如果您只需要页面的 ID,那么在您的第一个查询中执行 current_location.id 可能会获得更好的性能
您将要使用 fql.multiquery,这里有一个类似的答案可以根据您的需要量身定制:Facebook Graph API get all users and their status
有关多查询的 FQL 文档位于此处:http://developers.facebook.com/docs/reference/fql/
您是否也在尝试获取 checkin 对象的纬度/经度?如果是这样,您需要查看此资源:http://developers.facebook.com/docs/reference/fql/checkin/
编辑:
我不确定您尝试做的事情是否可行。我只是查看了 api 并测试了一些查询,从 friend 那里获得纬度/经度的唯一方法似乎是基于签到,如果有必要,你可以从那里获得页面上的详细信息......即使看着你的第二个查询,页表中的任何地方都没有引用 current_location_id,从页表中选择位置将为您提供它所属位置的位置信息。也许您可以详细说明您要完成的任务。
这是我在 PHP 中使用 FQL 编写的多查询语句(它将选择您所有 friend 签到的坐标,然后从那里获取有关该 friend 签到地点的详细信息):
try{
$multiQuery = "{
'query1':'SELECT coords, tagged_uids, page_id FROM checkin WHERE author_uid IN (SELECT uid2 FROM friend WHERE uid1 = me())',
'query2':'SELECT name, description FROM page WHERE page_id IN (SELECT page_id FROM #query1)'
}";
$param = array(
'method' => 'fql.multiquery',
'queries' => $multiQuery,
'callback' => ''
);
$queryresults = $facebook->api($param);
print_r($queryresults);
}
catch(Exception $o){
print_r($o);
}
关于facebook - 使用 Graph FQL 获取 friend 当前位置的纬度/经度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8846551/
我正在开发一个应用程序,用户可以在其中搜索其位置附近的项目。 当用户注册我的服务时,会获取他们的经/纬度坐标(这实际上是从邮政编码中获取的,然后通过 Google 查找经度/纬度坐标)。当用户添加一个
所以:我有以下函数,改编自在线找到的公式,它采用两个纬度/经度坐标并计算它们之间的距离(以英里为单位)(沿着球形地球): public static double distance (double l
我有一个给定点(经度、纬度),我想获取给定点 5 英里半径范围内的所有点范围? 最佳答案 我只是在这里猜测,但我认为您需要找到一种不同的方法。如果您尝试使用 Foursquare、Google map
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
我找到了一些代码,用于将纬度/经度转换为给定图像上的像素,反之亦然。我将其移植到 JavaScript,但在纬度上得到了不正确的返回值。我测试了原始的、未修改的代码,它给出了同样的不准确之处。下面是带
我用了AstroPy EarthLocation 获取传播卫星轨道的纬度、经度和高度 loc = coord.EarthLocation(*itrs.cartesian.xyz)。现在,我尝试使用 n
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: how to do location based search Getting similar longit
我有一个超过 15000 个经纬度坐标的列表。给定任何 X、Y 坐标,在列表中找到最近坐标的最快方法是什么? 最佳答案 您将需要使用名为 Voronoi diagram 的几何结构。 .这将平面划分为
For people interested in this topic: the accepted answer involves some concepts that I think are wel
我的应用程序上有一张 map ,它显示 2 种注释:位置和位置集群。当我放大集群时,集群会展开以显示集群中包含的位置。当这些位置添加到 map 时,其父簇的坐标将存储在注释对象中。我想要做的是制作一个
关于纬度/经度计算的简单问题。 我想获取一个值集,例如Lat: 55.123456 Long -6.123456 并计算出任意距离的四个点。 作为给定的正方形,我想计算出左侧和右侧的纬度值。因此红线距
Postgis中Linestring中的点(由osm2pgsql从osm导入)按顺序描述(经度,纬度) 例如慕尼黑 map 中的线串 'LINESTRING(11.4068032 47.8580927
给定左上长/纬度和右下长/纬度,我如何确定给定的长/纬度是否落在矩形内? 理想情况下我会看类似的东西 bool IsWithinArea(float topLeftLat,float topLeftL
几天来,我一直在尝试让纬度/经度检查器、速度计、高度计工作,但似乎没有任何工作。我尝试过使用 Android 的内置 locationmanager 和 google play 服务。现在我回来尝试
我有经纬度形式的位置坐标,例如:23⁰ 39' 24.8"N & 58⁰ 11' 36.5"E,请参见下图。但是在我的工作场所我使用 ArcGIS 并且它似乎不支持度数(纬度,经度)形式的坐标。我现在
网上看了一些教程,发现LocationManager就是这样做的。这是我在网上找到的代码。但是,我不明白。为什么我不能得到长/纬度?为什么要经历所有“改变”位置的事情...... lm=(Locati
我一直在关注此网站的教程:' http://wptrafficanalyzer.in/blog/storing-google-maps-android-api-v2-marker-locations-
我需要使用用户当前的纬度/经度和数据库中存储的一些值进行一些计算。问题是 Location.getLatitude() 返回一个类似 4119778.0 的值,而我在数据库中的值保存为 41.1675
所以在 PostgreSQL 中,我有一堆 long/lat 的几何值,其格式如下: 0101000020E610000095B9F94674CF37C09CBF0985083B5040 所以在 Po
在 GoogleMap 中,有标记的纬度和经度概念。 MySQL 中的 Point 数据类型有两个坐标 x 和 y。我不知道 Point 的坐标代表什么;所以我想知道什么表示 Point 根据 Goo
我是一名优秀的程序员,十分优秀!