jyc*_*753 7 php json laravel eloquent laravel-5
我正在尝试将JSON字段转换为数组.例如,模型是这样的:
protected $casts = [
'content' => 'array'
];
Run Code Online (Sandbox Code Playgroud)
在插入内容时,我这样做:
'content'=> json_encode([
'description' => $faker->paragraph(3),
'about' => $faker->paragraph(2),
'info' => $faker->paragraph(2),
'updated' => $faker->dateTimeBetween('-1 years', 'now')
]),
Run Code Online (Sandbox Code Playgroud)
但在获取数据时,它会打印一个字符串,而不是其他内容.
此部分中的迁移如下所示:
$campaign->json('content');
Run Code Online (Sandbox Code Playgroud)
输出样本:
"content": "{\"description\":\"Ut quas quo odio illo. Voluptates quia fuga itaque sint. Velit sapiente fugit ea ut ducimus sint tempora eligendi. Ea et molestiae consequuntur quibusdam soluta voluptatem.\",\"about\":\"Aut voluptates et iste ut perspiciatis. Esse sunt ullam inventore sit doloremque et quisquam.\",\"info\":\"Corrupti et facere exercitationem consequatur aspernatur quo saepe. Omnis et tempore enim ut. Quia magnam quia enim et eos enim.\",\"updated\":{\"date\":\"2015-11-22 08:25:13.000000\",\"timezone_type\":3,\"timezone\":\"UTC\"}}",
Run Code Online (Sandbox Code Playgroud)
有什么想法吗?
定义array演员表时,您不需要做任何json_encode或json_decode.当你想插入时,你需要做的很简单:
'content'=> [
'description' => $faker->paragraph(3),
'about' => $faker->paragraph(2),
'info' => $faker->paragraph(2),
'updated' => $faker->dateTimeBetween('-1 years', 'now')
],
Run Code Online (Sandbox Code Playgroud)
Laravel将完成剩下的工作
当你想获得content现场数据时,你只需要使用:
$campaign->content;
Run Code Online (Sandbox Code Playgroud)
你将在这里有数组,所以如果你想显示描述,你只需要做:
echo $campaign->content['description'];
Run Code Online (Sandbox Code Playgroud)
如果你想让你的头脑爆炸......
// automatically handles json_encode, json_decode to php object
protected $casts = [
'db_json_column' => 'object'
];
$model->db_json_column = $array; // persisted as json
$object = $model->db_json_column; // retrieved as object
Run Code Online (Sandbox Code Playgroud)
或者,
// automatically handles json_encode, json_decode to php array
protected $casts = [
'db_json_column' => 'array'
];
$model->db_json_column = $array; // persisted as json
$array = $model->db_json_column; // retrieved as array
Run Code Online (Sandbox Code Playgroud)