Выполнить FQL-запрос с помощью facebook c # sdk v6.0.10 - PullRequest
18 голосов
/ 19 марта 2012

Я бы хотел выполнить FQL для получения всех друзей пользователя приложения.

В предыдущих версиях SDK это можно было сделать с помощью:

var client = new FacebookWebClient();
client.Query(String.Format("SELECT uid, name FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = {0})", me.id));

, но с версией 6.0.10 Понятия не имею, как мне сделать то же самое.

Есть идеи?

Ответы [ 2 ]

25 голосов
/ 20 марта 2012

FQL

var fb = new FacebookClient("access_token");
dynamic result = fb.Get("fql", 
    new { q = "SELECT uid FROM user WHERE uid=me()" });

FQL Multi Query

var fb = new FacebookClient("access_token");
dynamic result = fb.Get("fql", new
    {
        q = new[]
                {
                    "SELECT uid from user where uid=me()",
                    "SELECT name FROM user WHERE uid=me()"
                }
    });

FQL с именем multi-query

var fb = new FacebookClient("access_token");
dynamic result = fb.Get("fql",
    new
        {
            q = new
            {
                id = "SELECT uid from user where uid=me()",
                name = "SELECT name FROM user WHERE uid " +
                "IN (SELECT uid FROM #id)",
            }
        });
17 голосов
/ 19 марта 2012

Вы можете фактически получить то же самое с вызовом Graph API:

var client = new FacebookClient();
var query = string.Format("SELECT uid, name FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = {0})", me.id);

dynamic parameters = new ExpandoObject();
parameters.q = query;
dynamic results = client.Get("/fql", parameters);
...