Heim  >  Artikel  >  Backend-Entwicklung  >  Migration der häufig verwendeten Aussagen von Lavarel

Migration der häufig verwendeten Aussagen von Lavarel

不言
不言Original
2018-04-19 10:10:261862Durchsuche

Der Inhalt dieses Artikels handelt von Migration, einer häufig verwendeten Aussage in Lavarel. Sie hat einen gewissen Referenzwert. Jetzt können Freunde in Not darauf verweisen.

Lavarel5. 2 Hauptsächlich müssen die vorherigen Teile häufig bedient werden, solange Sie die häufig verwendeten Anweisungsfunktionen beherrschen, wird es viel einfacher, sie zu implementieren


  1. Controller

  2. Modell

  3. Ansicht

  4. Route

  5. Migration


Migrationskapitel

1. Migration erstellen

in Geben Sie den Befehl in die Konsole ein
Der Befehl zum Erstellen einer Tabelle, wir sind es gewohnt, sie mit Verhalten zu benennen

php artisan make:migration create_users_table --create=users

Der Befehl zum Ändern der Tabelle

php artisan make:migration add_votes_to_users_table --table=users

Auf diese Weise befindet sich mehr in der Datei /database/migrations

2. Erstellen Sie den Befehl, der der Spalte

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

entspricht und der Typ in der entsprechenden Datenbank

命令 描述
$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');
  • 1

删除多个列:

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

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

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

版权声明:本文为博主原创文章,未经博主允许不得转载。            https://blog.csdn.net/qq_32198277/article/details/52592769





Das obige ist der detaillierte Inhalt vonMigration der häufig verwendeten Aussagen von Lavarel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn