MySQL — Как сохранить GraphObject facebook в PHP SDK4 в базе данных?

Я хочу сохранить пользовательские интересы в базе данных, используя php mysql. Вывод доступен в формате JSON в виде древовидной структуры, которую я напечатал с помощью print_r ():

  Facebook/GraphUser Object
(
[backingData:protected] => Array
(
[data] => Array
(
[0] => stdClass Object
(
[category]=> Tours/sightseeing
[category_list] => Array
(
[0] => stdClass Object
(
[id] => 209888929023118
[name] => Landmark
)
[1] => stdClass Object
......

Мой код:

  $user_interest = (new FacebookRequest($session, 'GET', '/me/interests'))  ->execute()->getGraphObject(GraphUser::className());

Для добавления данных в базу данных я нашел следующий код, но он не работает:

 for($i = 0; $i < sizeof($user_interest[data]); $i++)
{
$name = $user_interest[data][$i]['name'];
$category = $user_interest[data][$i]['category'];
$categoryId = $user_interest[data][$i]['id'];
//$created_time = $user_interest[data][$i]['created_time'];

$strsql = "INSERT INTO interests(categoryId,category,name)
VALUES($categoryId,$category,$name)";

if ($conn->query($sql) === TRUE) {
echo "New record created successfully";
}
else {
echo "Error: " . $sql . "<br>" . $conn->error; }

Пожалуйста, помогите, я действительно застрял здесь …

1

Решение

Решил это. Вот что я использовал

       $books = (new FacebookRequest($session, 'GET', '/me/books'))
->execute()->getGraphObject()->asArray();$booksarray=array();
for($i=0;$i<10;$i++){
$array = get_object_vars( $books['data'][$i]);
$booksarray[]=$array['name'];
}

Затем я просто сохранил массив в БД:

 function interests($booksarray, $fbid){
$query = "INSERT INTO Books      (uid,book1,book2,book3,book4,book5,book6,book7,book8,book9,book10)
VALUES ('$fbid','$booksarray[0]','$booksarray[1]','$booksarray[2]','$booksarray[3]','$booksarray[4]','$booksarray[5]','$booksarray[6]','$booksarray[7]','$booksarray[8]','$booksarray[9]')";

mysql_query($query);
}

Любое улучшение по сравнению с этим будет оценено. Спасибо

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]