我正在使用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();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。