我使用 Laravel 5.6。
我的模型是这样的:
class Product extends CachedModel {
protected $fillable = ['...','photo_list',];
protected $casts = [
'photo_list' => 'array'
];
public function scopeOfUpdate($query, $photoList) {
// echo '<pre>'; print_r($photoList); echo '</pre>'; die();
return $query->where('id', 1)->update(['photo_list' => $photoList]);
}
}
的结果:
echo '<pre>';
print_r($photoList);
echo '</pre>';
die();
是这样的:
Array
(
[id] => 1
[name] => tQQ8lGsIxHmfqH8HVGWz9cjwFFNvgEXgaUPnOsNO.png
)
如果执行代码,则存在如下错误:
数组到字符串的转换 (SQL: update
products
setphoto_list
= 1, ....
我遵循此文档:https ://laravel.com/docs/5.6/eloquent-mutators#array-and-json-casting将 json 数据保存到数据库。但似乎它不起作用。
我怎么解决这个问题?