laravel數據庫設計
外鍵約束
Laravel 還提供了創建外鍵約束的支持,用於在數據庫層面強制引用完整性。例如,我們在posts 表中定義了一個引用 users 表 id 列的 user_id 列:
Schema::table('posts', function (Blueprint $table) {
$table->integer('user_id')->unsigned();
$table->foreign('user_id')->references('id')->on('users');
});
你還可以爲約束的“on delete”和“on update”屬性指定期望的動作:
$table->foreign('user_id')
->references('id')->on('users')
->onDelete('cascade');
解釋: 第一種情況: 這是數據庫外鍵定義的一個可選項,用來設置當主鍵表中的被參考列的數據發生變化時,外鍵表中響應字段的變換規則的。update 則是主鍵表中被參考字段的值更新,delete 是指在主鍵表中刪除一條記錄: on update 和 on delete 後面可以跟的詞語有四個 no action , set null , set default ,cascade no action 表示 不做任何操作, set null 表示在外鍵表中將相應字段設置爲null set default 表示設置爲默認值 cascade 表示級聯操作 就是說,如果主鍵表中被參考字段更新,外鍵表中也更新,主鍵表中的記錄被刪除,外鍵表中改行也相應刪除 第二種情況: 只加 $table->foreign('user_id') ->references('id')->on('users');
當你刪除主表中的數據時,如果外鍵post表中有user_id的值,那麼將提示你不可以刪除user主表中的數據
命令 |
描述 |
---|---|
$table->bigIncrements('id'); |
等同於自增 UNSIGNED 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->dateTimeTz('created_at'); |
等同於 DATETIME 類型(帶時區)列 |
$table->decimal('amount', 5, 2); |
等同於 DECIMAL 類型列,帶精度和範圍 |
$table->double('column', 15, 8); |
等同於 DOUBLE 類型列,帶精度, 總共15位數字,小數點後8位 |
$table->enum('level', ['easy', 'hard']); |
等同於 ENUM 類型列 |
$table->float('amount', 8, 2); |
等同於 FLOAT 類型列,帶精度和總位數 |
$table->geometry('positions'); |
等同於 GEOMETRY 類型列 |
$table->geometryCollection('positions'); |
等同於 GEOMETRYCOLLECTION 類型列 |
$table->increments('id'); |
等同於自增 UNSIGNED INTEGER (主鍵)類型列 |
$table->integer('votes'); |
等同於 INTEGER 類型列 |
$table->ipAddress('visitor'); |
等同於 IP 地址類型列 |
$table->json('options'); |
等同於 JSON 類型列 |
$table->jsonb('options'); |
等同於 JSONB 類型列 |
$table->lineString('positions'); |
等同於 LINESTRING 類型列 |
$table->longText('description'); |
等同於 LONGTEXT 類型列 |
$table->macAddress('device'); |
等同於 MAC 地址類型列 |
$table->mediumIncrements('id'); |
等同於自增 UNSIGNED MEDIUMINT 類型列(主鍵) |
$table->mediumInteger('numbers'); |
等同於 MEDIUMINT 類型列 |
$table->mediumText('description'); |
等同於 MEDIUMTEXT 類型列 |
$table->morphs('taggable'); |
添加一個 UNSIGNED INTEGER 類型的 taggable_id 列和一個 VARCHAR 類型的 taggable_type 列 |
$table->multiLineString('positions'); |
等同於 MULTILINESTRING 類型列 |
$table->multiPoint('positions'); |
等同於 MULTIPOINT 類型列 |
$table->multiPolygon('positions'); |
等同於 MULTIPOLYGON 類型列 |
$table->nullableMorphs('taggable'); |
morphs() 列的 nullable 版本 |
$table->nullableTimestamps(); |
timestamps() 的別名 |
$table->point('position'); |
等同於 POINT 類型列 |
$table->polygon('positions'); |
等同於 POLYGON 類型列 |
$table->rememberToken(); |
等同於添加一個允許爲空的 remember_token VARCHAR(100) 列 |
$table->smallIncrements('id'); |
等同於自增 UNSIGNED SMALLINT (主鍵)類型列 |
$table->smallInteger('votes'); |
等同於 SMALLINT 類型列 |
$table->softDeletes(); |
新增一個允許爲空的 deleted_at TIMESTAMP 列用於軟刪除 |
$table->softDeletesTz(); |
新增一個允許爲空的 deleted_at TIMESTAMP (帶時區)列用於軟刪除 |
$table->string('name', 100); |
等同於 VARCHAR 類型列,帶一個可選長度參數 |
$table->text('description'); |
等同於 TEXT 類型列 |
$table->time('sunrise'); |
等同於 TIME 類型列 |
$table->timeTz('sunrise'); |
等同於 TIME 類型(帶時區) |
$table->timestamp('added_on'); |
等同於 TIMESTAMP 類型列 |
$table->timestampTz('added_on'); |
等同於 TIMESTAMP 類型(帶時區)列 |
$table->timestamps(); |
添加允許爲空的 created_at 和 updated_at TIMESTAMP 類型列 |
$table->timestampsTz(); |
添加允許爲空的 created_at 和 updated_at TIMESTAMP 類型列(帶時區) |
$table->tinyIncrements('numbers'); |
等同於自增的 UNSIGNED TINYINT 類型列(主鍵) |
$table->tinyInteger('numbers'); |
等同於 TINYINT 類型列 |
$table->unsignedBigInteger('votes'); |
等同於無符號的 BIGINT 類型列 |
$table->unsignedDecimal('amount', 8, 2); |
等同於 UNSIGNED DECIMAL 類型列,帶有總位數和精度 |
$table->unsignedInteger('votes'); |
等同於無符號的 INTEGER 類型列 |
$table->unsignedMediumInteger('votes'); |
等同於無符號的 MEDIUMINT 類型列 |
$table->unsignedSmallInteger('votes'); |
等同於無符號的 SMALLINT 類型列 |
$table->unsignedTinyInteger('votes'); |
等同於無符號的 TINYINT 類型列 |
$table->uuid('id'); |
等同於 UUID 類型列 |
$table->year('birth_year'); |
等同於 YEAR 類型列 |