Я расширил миграцию по умолчанию, добавив некоторые дополнительные поля таблицы для своей пользовательской таблицы.
Я хотел иметь created_at
а также updated_at
поля с timestamps
как значения.
Вот мой код
<?php
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
class CreateUsersTable extends Migration {
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('users', function(Blueprint $table)
{
$table->bigIncrements('id');
$table->bigInteger('group_id');
$table->string('fname',255);
$table->string('lname',255);
$table->string('email',255)->unique();
$table->string('password', 60);
$table->boolean('active');
$table->string('gravtar',255)->nullable();
$table->rememberToken();
$table->timestamps('created_at');
$table->timestamps('updated_at');
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::drop('users');
}
}
Препятствие при использовании двух столбцов меток времени не переносит таблицы и выдает это исключение
[PDOException]
SQLSTATE[42S21]: Column already exists: 1060 Duplicate column name 'created_at'
Смотри, у меня есть только один столбец с именем created_at
Так что это исключение не имеет смысла.
Однако, когда я опускаю одно из полей меток времени, таблица переносится.
Понятия не имею, что вызвало это?
Метод timestamps () добавляет столбцы create_at и updated_at. Также этот метод не принимает никаких аргументов.
http://laravel.com/api/5.0/Illuminate/Database/Schema/Blueprint.html#method_timestamps
http://laravel.com/docs/5.0/schema
Просто используйте $table->timestamp('col_name');
без s в конце timestamp