Lavarel の一般的に使用されるステートメントの移行

不言
リリース: 2023-03-24 11:32:01
オリジナル
1872 人が閲覧しました

この記事の内容は、Lavarel でよく使われる移行に関するもので、必要な友人に参考にしていただけるようにしました

Lavarel5.2 主要な部分は以前のものです。よく使うステートメントの機能をマスターすれば


  1. Controller

  2. Model

  3. View

  4. Route

  5. 移行


移行の章

1. 移行を作成する

コンソールにコマンドを入力します
テーブルを作成するコマンド、動作を使用してテーブルに名前を付けることに慣れています

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');
});
ログイン後にコピー

とデータベース内の対応するタイプを作成します

自動インクリメントID、タイプはbigintです $ table->bigInteger('votes');
コマンド説明
$table->bigIncrements('id');$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_atupdated_at列.
$table->uuid('id');
🎜 はデータベースの BIGINT 型と同等です 🎜🎜🎜🎜$table->binary('data'); 🎜🎜は同等です データベースの BLOB 型🎜🎜🎜🎜$table->boolean('confirmed');🎜🎜 はデータベースの BOOLEAN 型と同等です🎜🎜🎜🎜$table->char('name', 4);🎜🎜データベースの CHAR 型と同等です🎜🎜🎜🎜$table->date('created_at');< /code>🎜🎜はデータベースと同等です 🎜🎜🎜🎜<code>$table->dateTime('created_at');🎜🎜 の DATE 型はデータベース 🎜🎜 の DATETIME 型と同等です🎜🎜$table->decimal( 'amount', 5, 2);🎜🎜精度と範囲を備えたデータベースの DECIMAL 型と同等です🎜🎜🎜🎜$table ->double('column', 15, 8) ;🎜🎜データベースの DOUBLE 型と同等で、精度は小数点以下 8 桁の合計 15 桁です。🎜🎜🎜🎜< code>$table->enum('choices', ['foo' , 'bar']);🎜🎜 はデータベースの ENUM タイプと同等です 🎜🎜🎜🎜$table-&gt ;float('amount');🎜🎜 はデータベース FLOAT 型の ENUM 型と同等です🎜🎜🎜🎜$table->increments('id');🎜🎜データベースの主キー自動インクリメント ID🎜🎜🎜🎜$table->integer('votes') ;🎜🎜データベースの INTEGER 型と同等です🎜🎜🎜🎜$table ->json('options');🎜🎜はデータベースの JSON 型と同等です🎜🎜🎜🎜 $table->jsonb('options');🎜🎜データベースの JSONB 型と同等です🎜🎜🎜🎜$table->longText('description');</code >🎜🎜データベースの LONGTEXT 型と同等です🎜🎜🎜🎜<code>$ table->mediumInteger('numbers');🎜🎜データベースの MEDIUMINT 型と同等です🎜🎜🎜🎜$ table->mediumText('description');🎜 🎜データベースの MEDIUMTEXT 型と同等🎜🎜🎜🎜$table->morphs('taggable');🎜🎜 INTEGER 型の taggable_id 列とSTRING 型の taggable_type 列🎜🎜🎜🎜$table->gt;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);🎜🎜長さ🎜🎜🎜 🎜$table-> を持つデータベースの VARCHAR 列に相当します。 text('description');🎜🎜データベースのTEXT型と同等🎜🎜🎜🎜$table->time('sunrise');code>🎜🎜は同等ですデータベースの 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





以上がLavarel の一般的に使用されるステートメントの移行の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート