Migration des déclarations couramment utilisées de Lavarel

不言
Libérer: 2023-03-24 11:32:01
original
1872 Les gens l'ont consulté

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
Copier après la connexion
La commande pour modifier la table

php artisan make:migration add_votes_to_users_table --table=users
Copier après la connexion
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;);
});
Copier après la connexion
. et le type dans la base de données correspondante

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

3.修改列

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

Schema::table(&#39;users&#39;, function ($table) {

});
Copier après la connexion

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

$table->string(&#39;name&#39;, 50)->change();
Copier après la connexion

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

$table->string(&#39;name&#39;, 50)->nullable()->change();
Copier après la connexion

重命名列

 $table->renameColumn(&#39;from&#39;, &#39;to&#39;);
Copier après la connexion

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

删除列

$table->dropColumn(&#39;votes&#39;);
Copier après la connexion
  • 1

删除多个列:

$table->dropColumn([&#39;votes&#39;, &#39;avatar&#39;, &#39;location&#39;]);
Copier après la connexion
  • 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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal