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

我正在使用laravel的Model的copy()方法生成现有实例的副本.如果没有唯一的列,则效果很好

就我而言,有些列是唯一的,所以我使用了

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

这将确保如果产品被复制一次,它将处理唯一列问题.但是,如果再次复制产品,将再次导致问题.

我该如何解决这个问题

解决方法:

我将在数据库product_code ans名称中设置为可为空,然后执行以下操作:

$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();

当然,您可以将其包装到一个函数中,以防您在多个地方使用它.

相关文章

laravel的dd函数不生效怎么办
看不懂laravel文档咋办
安装laravel框架出现command怎么办
Laravel开发API怎么使用事务
laravel怎么构建复杂查询条件
laravel如何实现防止被下载