Migration方便于团队开发,它就像数据库的版本控制一样,它的功能就是可以和别人共享你的数据库结构。这么说可能不太好理解,你跟着敲敲就明白了。


0 前提工作-配置数据库

找到你根目录的 .env 文件配置你的数据库:

DB_HOST=127.0.0.1
DB_DATABASE=learn_laravel
DB_USERNAME=root
DB_PASSWORD=

1 数据表操作

1.1 创建表

使用Laravel后呢 创建一张表的时候就直接生成迁移吧:

php artisan make:migration create_bills_table --create=bills

我们已经创建了迁移文件 然后就可以在里面设计我们的表结构啦:

    public function up()
{
Schema::create('bills', function (Blueprint $table) {
$table->increments('id');
$table->string('name'); // 账单名称
$table->string('type'); // 账单类型
$table->timestamps();
});
}

确定没有问题就可以创建这张表了:

php artisan migrate

1.2 重命名表

首先生成一个改表名的迁移文件:

php artisan make:migration rename_bills_to_records --table=billes

其次 用rename方法就可以更改表名啦:

    public function up()
{
Schema::rename('bills','records');
}

最后 不要忘了执行迁移:

php artisan migrate

1.3 删除一张表

    Schema::drop('bills');
// or
Schema::dropExists('bills');

2 列操作

首先我先列出列都可以是哪些类型:

$table->bigIncrements('id'); 自增ID,类型为bigint
$table->bigInteger('votes'); 等同于数据库中的BIGINT类型
$table->binary('data'); 等同于数据库中的BLOB类型
$table->boolean('confirmed'); 等同于数据库中的BOOLEAN类型
$table->char('name', 4); 等同于数据库中的CHAR类型
$table->date('created_at'); 等同于数据库中的DATE类型
$table->dateTime('created_at'); 等同于数据库中的DATETIME类型
$table->decimal('amount', 5, 2); 等同于数据库中的DECIMAL类型,带一个精度和范围
$table->double('column', 15, 8); 等同于数据库中的DOUBLE类型,带精度, 总共15位数字,小数点后8位.
$table->enum('choices', ['foo', 'bar']); 等同于数据库中的 ENUM类型
$table->float('amount'); 等同于数据库中的 FLOAT 类型
$table->increments('id'); 数据库主键自增ID
$table->integer('votes'); 等同于数据库中的 INTEGER 类型
$table->json('options'); 等同于数据库中的 JSON 类型
$table->jsonb('options'); 等同于数据库中的 JSONB 类型
$table->longText('description'); 等同于数据库中的 LONGTEXT 类型
$table->mediumInteger('numbers'); 等同于数据库中的 MEDIUMINT类型
$table->mediumText('description'); 等同于数据库中的 MEDIUMTEXT类型
$table->morphs('taggable'); 添加一个 INTEGER类型的 taggable_id 列和一个 STRING类型的 taggable_type
$table->nullableTimestamps(); 和 timestamps()一样但不允许 NULL值.
$table->rememberToken(); 添加一个 remember_token 列: VARCHAR(100) NULL.
$table->smallInteger('votes'); 等同于数据库中的 SMALLINT 类型
$table->softDeletes(); 新增一个 deleted_at 列 用于软删除.
$table->string('email'); 等同于数据库中的 VARCHAR 列  .
$table->string('name', 100); 等同于数据库中的 VARCHAR,带一个长度
$table->text('description'); 等同于数据库中的 TEXT 类型
$table->time('sunrise'); 等同于数据库中的 TIME类型
$table->tinyInteger('numbers'); 等同于数据库中的 TINYINT 类型
$table->timestamp('added_on'); 等同于数据库中的 TIMESTAMP 类型
$table->timestamps(); 添加 created_at 和 updated_at列.

2.1 向已有数据表中插入若干列数据

比如说 我这次向增加price列 就可以这样命名迁移文件:

php artisan make:migration add_price_intro_records --table=records 

之后咱就可以组织迁移架构 增添咱们想要添加的列啦:

    public function up()
{
Schema::table('records', function (Blueprint $table) {
$table->integer('price');
});
} /**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::table('records', function (Blueprint $table) {
$table->dropColumn('price');
});
}

注:不要忘记生成对应down方法的操作。

执行迁移:

php artisan migrate

2.2 在已有的表中修改列

注意:我们修改列之前 必须要引入一个"doctrine/dbal"包 如果没有引入的话 用composer引入一下就可以了。

2.2.1 修改列的一系列属性

我们在之前新增加了一个price列 现在我们来改改它玩儿 首先生成migration:

php artisan make:migration change_price_from_records --table=records

使用change方法来修改某一列:

    public function up()
{
Schema::table('records', function (Blueprint $table) {
$table->string('price','50')->nullable()->change();
});
}

之前price是int类型,经过修改 我们把它改为50长度的varchar类型 并且可以为空。

最后 执行迁移:

php artisan migrate

2.2.2 为已存在的列重命名

那个。。。。生成迁移和执行迁移的代码我就不再往上贴了啊,我们直接看代码怎样写吧:

    public function up()
{
Schema::table('records', function (Blueprint $table) {
$table->renameColumn('price','quantity');
});
}

2.3 删除列

可以指定删除一个列 也可以是若干个列:

    public function up()
{
Schema::table('records', function (Blueprint $table) {
$table->dropColumn('price');
// or
$table->dropColumn(['price,type']);
});
}

2.4 列修改器

修改器的类型有:

->first() 将该列置为表中第一个列 (仅适用于MySQL)
->after('column') 将该列置于另一个列之后 (仅适用于MySQL)
->nullable() 允许该列的值为NULL
->default($value) 指定列的默认值
->unsigned() 设置 integer 列为 UNSIGNED(无符号的 不能为负数)

举例:

    public function up()
{
Schema::table('records', function (Blueprint $table) {
$table->integer('price')->unsigned();
});
}

2.5 定义索引

索引的类型有:

$table->primary('id'); 添加主键索引
$table->primary(['first', 'last']); 添加混合索引
$table->unique('email'); 添加唯一索引
$table->index('state'); 添加普通索引

举例:

    public function up()
{
Schema::table('records', function (Blueprint $table) {
$table->string('email')->unique(); // 邮箱是唯一的
});
}

2.6 删除索引

$table->dropUnique('email');

3 外键关联

创建外键关联很简单:

    public function up()
{
Schema::create('records', function (Blueprint $table) {
$table->increments('id');// 当列都声明完后 编写外联:
$table->integer('user_id')->unsigned(); $table->foreign('user_id')->references('id')->on('users');
// or
$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
// or
$table->foreign('user_id')->references('id')->on('users')->onUpdate('cascade');
});
}

那么 如何删除一个外键呢?请看下列代码:

$table->dropForeign('records_user_id_foreign');

解读:'records_user_id_foreign' 这个参数是这样拼的:当前表名(records) + 外键名(user_id) + _foreign后缀

Laravel5.1 Migration数据库迁移文件的更多相关文章

  1. 【6】Laravel5.1的migration数据库迁移

    查看Laravel5.1的目录 当你配置好数据库后,在命令行执行下边的操作 php artisan migrate 打开数据库会发现,我们的数据库多了四个表,神奇吧! 打开任意一个migration查 ...

  2. Laravel 5 数据库迁移文件示例

    php artisan make:migration create_stocks_table 在项目根目录执行上面的命令后,会在database/migrations目录下生成2016_06_03_1 ...

  3. laravel中的数据库迁移

    1.创建数据库迁移文件:生成数据库迁移文件,前面跟着时间戳: php artisan make:migration create_posts_table 创建数据库迁移文件:可以重命名数据表名: -- ...

  4. laravel中数据库迁移的使用:

    创建数据库迁移文件: php artisan make:migration create_links_table 创建完表之后,设置字段: public function up() { Schema: ...

  5. Laravel中如何做数据库迁移

    总的来说,做一次独立数据库迁移只需要三步,分别是创建迁移文件.修改迁移文件.运行迁移 1.创建数据库迁移文件php artisan make:migration create_articles_tab ...

  6. Laravel 6.X 数据库迁移 创建表 与 修改表

    数据库迁移创建表 本篇文章中使用的是mysql数据库,其他数据库需要修改env文件和app配置,请其他地方搜索一下就会找到. 创建示例 1.创建users表: 命令行键入 php artisan ma ...

  7. django中的数据库迁移

    Django是用python写的web开发框架,其特点是: 1.重量级框架,内部封装了很多的功能组件,使开发变的简便快速, 2.MVT模式:前后端分离,高内聚低耦合,m:model,与mvc中的m功能 ...

  8. Flask flask-migrate 数据库迁移

    简介 flask-migrate是flask的一个扩展模块,主要是扩展数据库表结构的. 官方文档:http://flask-migrate.readthedocs.io/en/latest/ 使用: ...

  9. django生成迁移文件和执行迁移的命令

    生成迁移文件: python manage.py makemigrations    #创建数据库迁移文件 执行迁移: python manage.py migrate    # 根据数据库迁移文件生 ...

随机推荐

  1. Java程序员到架构师的推荐阅读书籍

    作为Java程序员来说,最痛苦的事情莫过于可以选择的范围太广,可以读的书太多,往往容易无所适从.我想就我自己读过的技术书籍中挑选出来一些,按照学习的先后顺序,推荐给大家,特别是那些想不断提高自己技术水 ...

  2. unity 部分obj不接受后处理

    考虑了很多方案,比如渲染次序和mask(stencilebuffer) 渲染次序 sorting order(深度) renderer都有的属性能开放出来,sprite renderer原本就开放在i ...

  3. apache poi合并单元格设置边框

    HSSFWorkbook wb = new HSSFWorkbook(); HSSFSheet sheet = wb.createSheet(); //创建一个样式 HSSFCellStyle sty ...

  4. Yii2-核心框架代码规范

    1.概述 简单说,我们使用PSR-2兼容规范,所以应用于PSR-2的一切对我们的代码也同样适用. 文件必须使用 <?php 或 <?= 标签. 文件未尾应该有一个新行. PHP代码文件必须 ...

  5. jquery如何判断checkbox(复选框)是否被选中 全选 反选

    好长时间没用jq, 之前用的都是ng. 想着随便参考一下,结果被坑.因为这篇文章是09年的,也和当时jq的版本号有关,但是为什么在百度排名第一,百度果然坑人,以后还是google 给出坑人文章的链接 ...

  6. B5:责任链模式 Chain Of Responsibility

    使多个对象都有机会处理处理请求,从而避免请求的发送者和接受者之间的耦合关系.将这个对象连成一条链,并沿着该链处理请求,直到有一个对象能够处理它为止. 相当于switch/case,在客户端指定了每一链 ...

  7. AND、OR运算符的组合使用

    6.2.3  AND.OR运算符的组合使用 在WHERE子句中,通过AND.OR运算符能够同一时候连接多个条件.当然AND.OR运算符也能够同一时候使用.可是当AND.OR运算符同一时候存在时,其优先 ...

  8. C++ 和 java 使用 AES CBC 128 加解密

    Java 使用jce, code: import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax ...

  9. map方法,以及filter方法的使用

    map()方法,会返回一个 jQuery 封装的数组, 这个数组不能直接使用,需要使用 get() 来处理返回的对象以得到基础的数组. 例子: <!DOCTYPE html> <ht ...

  10. Tomcat中work目录的作用

    今天在修改了某个jsp后发现:tomcat容器启动后,访问该jsp返回的结果依然是修改之前的内容,略感不解,于是乎研究了一下Tomcat中work目录的作用. Tomcat中work目录的作用: js ...