У меня есть эта Laravel структура миграции:
class CreateWarehouseProductTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('warehouse_products', function (Blueprint $table) {
$table->bigIncrements('id');
$table->integer('product_id')->default(0);
$table->integer('warehouse_id');
$table->integer('free_amount')->default(0);
$table->integer('booked_amount')->default(0);
// ...
$table->timestamps();
});
}
// ...
}
Мне нужно создать ежедневную резервную копию из складских продуктов, и для этого мне нужно создать новую таблицу, которая точно такая же, как warehouse_products
и содержит еще одно дополнительное поле для даты резервной копии.
Есть ли какие-нибудь рекомендации для этого? Мне кажется, что-то вроде этого:
class CreateWarehouseProductBackupTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('warehouse_product_backups', function (Blueprint $table) {
CreateWarehouseProductTable->cloneFieldsToHere();
$table->date('date_of_backup');
});
}
}
Есть ли что-то подобное передовой практике клонирования полей из существующей миграции?