美文网首页Laravel
PHP日记——Lavarel常用语句之Migration篇

PHP日记——Lavarel常用语句之Migration篇

作者: 饥渴计科极客杰铿 | 来源:发表于2016-09-20 09:26 被阅读748次

    Lavarel5.2主要有以前几个部分要经常操作,只要掌握常用的语句功能实现起来就变得轻松很多了

    1. Controller
    2. Model
    3. View
    4. Route
    5. Migration

    Migration篇

    1.创建Migration

    在控制台输入命令
    创建表的命令,我们习惯用行为命名

    php artisan make:migration create_users_table --create=users
    

    修改表的命令

    php artisan make:migration add_votes_to_users_table --table=users
    

    这样在/database/migrations里就多了一些文件

    2.创建列

    Schema::create('users', function ($table) {
        $table->increments('id');
        $table->string('name');
    });
    

    对应的命令和相应数据库里的类型

    命令 描述
    $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列.
    $table->uuid('id'); 等同于数据库的UUID

    3.修改列

    如果我们执行的是类似第二行命令的话
    新生成migration里up方法的Create就会变成table,然后就可以在方法里写修改的一些代码

    Schema::table('users', function ($table) {
       
    });
    

    我们将name列的尺寸从 25 增加到 50:

    $table->string('name', 50)->change();
    

    我们还可以修改该列允许 NULL 值:

    $table->string('name', 50)->nullable()->change();
    

    重命名列

     $table->renameColumn('from', 'to');
    

    注意:暂不支持 enum类型的列的重命名。

    删除列

    $table->dropColumn('votes');
    

    删除多个列:

    $table->dropColumn(['votes', 'avatar', 'location']);
    

    以上就是一些Migration的常用语句,学会Migration可以节省大量用命令行建表的时间

    我把整个Lavarel系列的所有链接都更新了,欢迎大家点评

    相关文章

      网友评论

        本文标题:PHP日记——Lavarel常用语句之Migration篇

        本文链接:https://www.haomeiwen.com/subject/nvznettx.html