Генерация результата запроса JSON в Codeigniter - PullRequest
0 голосов
/ 29 августа 2018

Итак, у меня есть таблица базы данных с именем usermeta и структура таблицы, подобная этой:

-----------------------------------------------------------
| ummeta_id | user_id | meta_key    | meta_value          |
-----------------------------------------------------------
| 1         | 1       | fullname    | John Doe            |
| 2         | 1       | birthplace  | New York            |
| 3         | 1       | birthdate   | 1990/01/01          |
| 4         | 1       | mobile      | 0812-3456-7890      |
| 5         | 1       | email       | john.doe@mail.com   |
| 6         | 2       | fullname    | Jon Wick            |
| 7         | 2       | birthplace  | Washington DC       |
| 8         | 2       | birthdate   | 1985/10/21          |
| 9         | 2       | mobile      | 0890-1234-5678      |
| 10        | 2       | email       | wickjohn@mail.com   |

И я пытаюсь сгенерировать данные json для всех данных из этой базы данных, используя Codeigniter (v 3.1.9), используя Controller и Model.

Это моя модель (название модели: db_usermeta)

function userslist()
{
   $query = $this->db->select('*')
                     ->from('usermeta')
                     ->get();
   return $query->result();
}

Это мой Контроллер

public function userlist()
{
   header('Content-Type: application/json; charset=utf-8');
   $query = $this->db_usermeta->userslist();
   $json_data = array();
   foreach ($query as $key)
   {
      $json_data[$key->meta_key] = $key->meta_value;
   }
   echo json_encode($json_data);
}

В результате, когда я открываю с помощью своего браузера, чтобы проверить данные json с помощью инструмента веб-разработчика, отображается только последняя запись, в этом случае отображаются только данные из user_id 2, например:

{
  "fullname":"John Wick",
  "birthplace":"Washinton DC",
  "birthdate":"1985/10/21",
  "mobile":"0890-1234-5678",
  "email":"wickjohn@mail.com"
}

Чего я хочу добиться, так это показать все вложенные данные json следующим образом:

"data": [
  {
    "fullname":"John Doe",
    "birthplace":"New York",
    "birthdate":"1990/01/01",
    "mobile":"0812-3456-7890",
    "email":"john.doe@mail.com"
  },
  {
    "fullname":"John Wick",
    "birthplace":"Washinton DC",
    "birthdate":"1985/10/21",
    "mobile":"0890-1234-5678",
    "email":"wickjohn@mail.com"
  }
]

Как мне этого добиться? Я сделал ошибку на моем контроллере и модели. Я очень ценю вашу помощь.

Ответы [ 2 ]

0 голосов
/ 29 августа 2018

ваш $key->meta_key перезаписывается для каждой записи. поэтому появилась только последняя запись. На самом деле вам не нужно циклически проходить, чтобы получить данные JSON.

public function userlist()
{
   header('Content-Type: application/json; charset=utf-8');
   $query = $this->db_usermeta->userslist();
   $json_data = array(array());
   $user_id_map = array();
   $index = 0;
   foreach ($query as $key)
   {
        if(!isset($user_id_map[$key->user_id])){
            $user_id_map[$key->user_id] = $index++;
        }
        $currentIndex = $user_id_map[$key->user_id];
        $json_data[$currentIndex][$key->meta_key] = $key->meta_value;
   }
   echo json_encode($json_data);
}

просто измените свой код контроллера на этот код, и он вернет данные json.

0 голосов
/ 29 августа 2018

Поскольку мета-ключ fullname одинаков для обеих записей, необходимо изменить имя ключа на что-то уникальное

foreach ($query as $key)
   {
      $json_data[$key->meta_key] = $key->meta_value;
   }

Изменить $json_data[$key->meta_key] на $json_data[$key->meta_key.$key->user_id] или просто измените его на $json_data[$key->ummeta_id]

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...