我正在使用laravel的replicate()
Model方法来生成现有实例的副本。如果没有任何列将工作正常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_code
和name
为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();
当然,您可以将其包装到一个函数中,以防您在多个位置执行该操作。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句