0

facebook php sdk を使用して、他の誰かがその人の壁に投稿したすべての投稿のコメントのリストを取得しようとしています。次のように、バッチ API 要求で FQL を使用しています。

$getStream   = urlencode("method/fql.query?query=SELECT post_id, actor_id, target_id, source_id,viewer_id, message FROM stream WHERE app_id= '' and message != '' and source_id=$fbprofileId and target_id=$fbprofileId and is_hidden=0 limit 100");
$getComments = urlencode("method/fql.query?query=select object_id, post_id, fromid, time, text, id, likes, comments, user_likes, is_private from comment where post_id in({result=get-stream:$.*.post_id})");
$queries = array(
                     array('method'                   => 'POST',
                           'omit_response_on_success' => false,
                           'name'                     => 'get-stream',
                           'relative_url'             => $getStream),
                     array('method'                   => 'POST',
                           'omit_response_on_success' => false,
                           'name'                     => 'get-comments',
                           'relative_url'             => $getComments)
                );
return $this->fbApi->api('?batch='.json_encode($queries), 'POST');

fb から次の応答が返ってきました。

 {"error_code":601,"error_msg":"Parser error: unexpected '_1831955838114' at position 63.","request_args":[{"key":"method","value":"fql_query"},{"key":"format","value":"json"},{"key":"_fb_batch_child_request","value":"1"},{"key":"query","value":"select user_id, object_id from like where post_id in(1216940586_1831955838114,1216940586_1831891396503,1216940586_1831423824814,1216940586_1828915522108,1216940586_1822006149378,1216940586_1820687356409,1216940586_1813971228510,1216940586_1809392594047,1216940586_1795412004541,1216940586_1795177518679)"},{"key":"_fb_url","value":"method\/fql.query"},{"key":"access_token","value":"AAAC02IZB..."}]}

post_ids を引用符で囲む必要があることは明らかです。実際、同じクエリ fb グラフ api エクスプローラーを使用して、IN 句で引用符で囲まれた post_ids を使用すると、問題なく結果が得られます。

**post_id は文字列 (int ではありません) であるため、依存する Batch API FQL クエリのコンテキストで FQL IN 句への適切な引数にするために、それらを引用符で囲むにはどうすればよいですか? **

4

2 に答える 2

0

おそらく少し遅れていますが、代替として、FQL API は型を正しく処理するバッチ クエリをサポートしています: http://developers.facebook.com/docs/reference/fql/

クエリの JSON マップを作成し、一緒に送信します。

https://graph.facebook.com/fql?q={
  "friends":"SELECT uid2 FROM friend WHERE uid1=me()",
  "with_birthdays":"SELECT uid, name FROM user WHERE uid IN (select uid2 from #friends) and birthday_date"
}&access_token=yourToken29873

これらのクエリは明らかにエンコードされています (読みやすいようにエンコードされていません)。バッチ API 内でこれに対する解決策を見つけることができるかどうかを確認しますが、何か見つかったら編集します。

(編集:ここでは運がありません。申し訳ありません。かなり試してみましたが、エラーも結果も得られないか、パーサーエラーが発生します)

于 2011-12-07T19:52:50.047 に答える
-1

これが解決策のようです: '{result=get-stream:$.*.post_id}'

だからそうあるべきだ $getComments = urlencode("method/fql.query?query=select object_id, post_id, fromid, time, text, id, likes, comments, user_likes, is_private from comment where post_id in( '{result=get-stream:$.*.post_id}' )");

于 2013-04-26T02:54:33.543 に答える