溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

migrate如何在Laravel中使用

發(fā)布時(shí)間:2021-03-30 16:14:42 來源:億速云 閱讀:240 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章給大家介紹migrate如何在Laravel中使用,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

生成遷移

命令:

Migration

php artisan make:migration create_users_table

意思:創(chuàng)建一個(gè)遷移,其實(shí)就是創(chuàng)建一張名為users的表。

接著你便能在database/migrations這個(gè)目錄下找到與2014_10_12_000000_create_users_table.php這個(gè)類似的文件。
和以前用php語句創(chuàng)建表一樣,我們可以在2014_10_12_000000_create_users_table.php這個(gè)文件中寫上我們要創(chuàng)建表的字段及約束條件。

–table和–create選項(xiàng)可以用于指定表名以及該遷移是否要創(chuàng)建一個(gè)新的數(shù)據(jù)表。這些選項(xiàng)只需要簡單放在上述遷移命令后面并指定表名,如果你想要指定生成遷移的自定義輸出路徑,在執(zhí)行make:migration命令時(shí)可以使用–path選項(xiàng),提供的路徑應(yīng)該是相對于應(yīng)用根目錄的。

遷移結(jié)構(gòu)

一個(gè)migration類包含兩個(gè)方法up和down。

up中主要包含創(chuàng)建表的具體內(nèi)容。

down中和前者相反。

Schema::create接受兩個(gè)參數(shù)。第一個(gè)是你要創(chuàng)建表的表名;第二個(gè)是一個(gè)閉包(匿名函數(shù)),獲取用于定義新表的 Blueprint 對象。

Migration

<?php
 
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
 
class CreateUsersTable extends Migration
{
 /**
  * Run the migrations.
  *
  * @return void
  */
 public function up()
 {
  Schema::create('users', function (Blueprint $table) {
   $table->increments('id');
   $table->string('name');
   $table->string('email')->unique();
   $table->string('password');
   $table->rememberToken();
   $table->timestamps();
  });
 }
 
 /**
  * Reverse the migrations.
  *
  * @return void
  */
 public function down()
 {
  Schema::dropIfExists('users');
 }
}

運(yùn)行遷移

要運(yùn)行應(yīng)用中所有未執(zhí)行的遷移,可以使用 Artisan 命令的migrate方法。

Migration

php artisan migrate

回滾遷移

想要回滾最新的一次遷移”操作“,可以使用rollback命令,注意這將會回滾最后一批運(yùn)行的遷移,可能包含多個(gè)遷移文件:

Migration

php artisan migrate:rollback

migrate:reset命令將會回滾所有的應(yīng)用遷移:

Migration

php artisan migrate:reset

在單個(gè)命令中回滾/遷移

migrate:refresh命令將會先回滾所有數(shù)據(jù)庫遷移,然后運(yùn)行migrate命令。這個(gè)命令可以有效的重建整個(gè)數(shù)據(jù)庫:

Migration

php artisan migrate:refresh
php artisan migrate:refresh --seed

常用遷移屬性

$table->increments(‘id');數(shù)據(jù)庫主鍵自增 ID
$table->integer(‘votes');等同于數(shù)據(jù)庫中的 INTEGER 類型
$table->float(‘a(chǎn)mount');等同于數(shù)據(jù)庫中的 FLOAT 類型
$table->char(‘name', 4);等同于數(shù)據(jù)庫中的 CHAR 類型
$table->dateTime(‘created_at');等同于數(shù)據(jù)庫中的 DATETIME 類型
$table->enum(‘choices', [‘foo','bar']);等同于數(shù)據(jù)庫中的 ENUM 類型
$table->tinyInteger(‘numbers');等同于數(shù)據(jù)庫中的 TINYINT 類型
$table->timestamps();添加 created_at 和 updated_at 列

一些列名約束條件的寫法

Migration

Schema::table('users', function ($table) {
 $table->integer('votes')->unsigned(); //無符號類型
});

常用約束

->first()將該列置為表中第一個(gè)列 (僅適用于 MySQL)
->after(‘column')將該列置于另一個(gè)列之后 (僅適用于 MySQL)
->nullable()允許該列的值為 NULL
->default($value)指定列的默認(rèn)值
->unsigned()設(shè)置 integer 列為 UNSIGNED

關(guān)于migrate如何在Laravel中使用就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI