我正在运行Laravel Framework version 5.2.45,并且想要迁移数据库迁移。

我有两次迁移。一个是现成的标准2014_10_12_100000_create_password_resets_table,另一个是我新创建的迁移2017_02_19_172350_create_keywords_table

<?php

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateKeywordsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('keywords', function (Blueprint $table) {
            $table->increments('id');
            $table->string('keyword');
            $table->timestamps();
            $table->timestamps('published_at');

        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::drop('keywords');
    }
}


做我得到的典型php artisan migrate(回滚之前):

root:~/workspace $ php artisan migrate:rollback
Rolled back: 2014_10_12_100000_create_password_resets_table
root:~/workspace $ php artisan migrate


  [Illuminate\Database\QueryException]
  SQLSTATE[42S21]: Column already exists: 1060 Duplicate column name 'created_at' (SQL: create table `keywords` (`id` int unsigned not null auto_incr
  ement primary key, `keyword` varchar(255) not null, `created_at` timestamp null, `updated_at` timestamp null, `created_at` timestamp null, `updated
  _at` timestamp null) default character set utf8 collate utf8_unicode_ci)



  [PDOException]
  SQLSTATE[42S21]: Column already exists: 1060 Duplicate column name 'created_at'


root:~/workspace $


在数据库内部未创建表keywords

php - Laravel迁移-列已存在-LMLPHP

有什么建议我做错了吗?

感谢您的答复!

最佳答案

$table->timestamps();是一个始终会添加created_atupdated_at字段的函数。在您的情况下,您要添加两次。如果要添加另一个时间戳字段,则必须使用timestamp()函数。

因此,您应使用以下内容替换published_at的行(删除s):

$table->timestamp('published_at');


the documentation中可以找到所有可能的列类型的列表。

09-25 18:02
查看更多