<?php use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class CreateSamplesTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::create('samples', function (Blueprint $table) { $table->increments('id'); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('samples'); } }
我们看到,这个类中有up和down两个方法。up中我们需要添加创建数据表的函数,以及添加各个栏目的名称及属性。而down方法中我们需要添加在回滚该迁移文件时应该有什么样的结果(这里我们直接删除这张表)。
可以看出,up和down中的操作是对应的,在up中进行了什么操作,down中就需要撤销这些操作。
现在我们详细来看一下up方法。我们看到,Schema::create这个方法是用来创建我们数据表的,在方法中,我们看到Laravel已经为我们填充了几个columns。
$table->increments('id')将创建一个名为id的column,并赋予PRIMARY KEY、UNSIGNED及AUTO INCREMENT属性。
$table->timestamps()将创建created_at和updated_at两个column(类型是DATETIME)。
注意:Laravel默认认为每个table都会存在一个id栏目,并且要求每个table都要有created_at和updated_at这两个栏目。
现在,我们要在samples表里增加一个名为name的VARCHAR类型的栏目,该怎么做呢?
很简单,只需要加上这行:
$table->string('name');
如果我们想限制VARCHAR的长度,可以在第二个参数中进行注明:
$table->string('name', 100);
好了,我们暂时就只需要这些栏目。现在我们已经有了迁移文件了,怎么样才能在数据库里建立起我们的表呢?
很简单,输入
$ php artisan migrate
等待命令完成就可以了。
现在我们在数据库里,就能看到我们的samples表了。
注意:运行php artisan migrate之前请检查你的.env文件中DB_DATABASE,DB_USERNAME,DB_PASSWORD 几项配置是否正确。如果你在Homestead下进行Laravel开发,那么DB_USERNAME默认为homestead,DB_PASSWORD默认为secret,DB_DATABASE请根据你的项目具体填入你的数据库名称。
现在问题来了,我们突然想在samples表里,添加一个名为url的栏目,该怎么做呢?我们分情况讨论。