gpt4 book ai didi

mysql - Laravel 5 replicate() 处理具有唯一属性的列

转载 作者:可可西里 更新时间:2023-11-01 08:04:18 24 4
gpt4 key购买 nike

我正在使用模型的 laravel 的 replicate() 方法来生成现有实例的副本。如果没有要unique

的列,它工作正常

在我的例子中,有些列是唯一的,所以我使用这个

    $pr = Products::find(\Input::get('id'))->replicate();
$pr['product_code'] = $pr->product_code . '_'.$pr['id'];
$pr['name'] = $pr->name . '_'.$pr['id'];
$pr->save();

这将确保如果产品被复制一次,它将处理唯一列问题。但如果再次复制该产品,就会再次出现问题。

我该如何解决这个问题

最佳答案

我会在数据库中将 product_codename 设置为 nullables,然后执行如下操作:

$product = Products::find(\Input::get('id'));
$newProduct = $product->replicate(['product_code', 'name']);
$newProduct->save();
$newProduct->product_code = $product->product_code.'_'.$newProduct->id;
$newProduct->name = $product->name.'_'.$newProduct->id;
$newProduct->save();

当然,您可以将其包装到一个函数中,以防您在多个地方执行此操作。

关于mysql - Laravel 5 replicate() 处理具有唯一属性的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37364920/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com