Maison >développement back-end >tutoriel php >Migration des déclarations couramment utilisées de Lavarel

Migration des déclarations couramment utilisées de Lavarel

不言
不言original
2018-04-19 10:10:261928parcourir

Le contenu de cet article concerne la migration, une déclaration couramment utilisée à Lavarel. Elle a une certaine valeur de référence. Maintenant, je la partage avec vous. Les amis dans le besoin peuvent s'y référer

Lavarel5. 2 Principalement, les parties précédentes doivent être utilisées fréquemment. Tant que vous maîtriserez les fonctions d'instruction couramment utilisées, il deviendra beaucoup plus facile de les mettre en œuvre


    <.>
  1. Contrôleur

  2. Modèle

  3. Vue

  4. Route

  5. Migration


Chapitre sur la migration

1.

dans Entrez la commande dans la console

La commande pour créer une table, on a l'habitude de la nommer avec un comportement

php artisan make:migration create_users_table --create=users
La commande pour modifier la table

php artisan make:migration add_votes_to_users_table --table=users
De cette façon il y en aura plus dans /database/migrations Fichier

2 Créez la commande correspondant à la colonne

Schema::create(&#39;users&#39;, function ($table) {    $table->increments(&#39;id&#39;);    $table->string(&#39;name&#39;);
});
. et le type dans la base de données correspondante

命令 描述
$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(&#39;users&#39;, function ($table) {

});

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

$table->string(&#39;name&#39;, 50)->change();

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

$table->string(&#39;name&#39;, 50)->nullable()->change();

重命名列

 $table->renameColumn(&#39;from&#39;, &#39;to&#39;);

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

删除列

$table->dropColumn(&#39;votes&#39;);
  • 1

删除多个列:

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

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

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

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





Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn