【发布时间】:2018-08-29 19:08:44
【问题描述】:
所以我有一个名为 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 |
我尝试使用 Codeigniter (v 3.1.9) 使用 Controller 和 Model 为该数据库中的所有数据生成 json 数据。
这是我的模型(模型名称: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);
}
当我使用浏览器打开使用web开发工具检查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"
}
]
我怎样才能做到这一点?我在控制器和模型上犯了错误吗?非常感谢您的帮助。
【问题讨论】:
标签: php arrays json codeigniter codeigniter-3