1

我使用 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 productsset photo_list= 1, ....

我遵循此文档:https ://laravel.com/docs/5.6/eloquent-mutators#array-and-json-casting将 json 数据保存到数据库。但似乎它不起作用。

我怎么解决这个问题?

4

1 回答 1

1

查询范围并不意味着更新记录。

在您的控制器中尝试这样的操作:

$product = Product::find(1);

$product->photo_list = [1, 2, 3];

$product->save();
于 2018-02-26T01:02:12.433 回答