Выполнить запрос FQL с помощью facebook С# sdk v6.0.10
Я хотел бы выполнить 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 я понятия не имею, как я могу сделать то же самое.
Любые идеи?
Ответы
Ответ 1
Фактически вы можете получить то же самое с вызовом 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);
Ответ 2
FQL
var fb = new FacebookClient("access_token");
dynamic result = fb.Get("fql",
new { q = "SELECT uid FROM user WHERE uid=me()" });
Многопользовательский запрос FQL
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)",
}
});