首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
数据库迁移-介绍
数据库迁移-生成迁移
数据库迁移-整合迁移
数据库迁移-迁移结构
数据库迁移-执行迁移
数据库迁移-回滚迁移
数据库迁移-数据表
数据库迁移-创建数据表
数据库迁移-更新数据表
数据库迁移-重命名 / 删除表
数据库迁移-字段
数据库迁移-创建字段
数据库迁移-可用的字段类型
数据库迁移-字段修饰符
数据库迁移-修改字段
数据库迁移-重命名字段
数据库迁移-删除字段
数据库迁移-索引
数据库迁移-创建索引
数据库迁移-重命名索引
数据库迁移-删除索引
数据库迁移-外键约束
数据库迁移-事件
数据填充-简介
数据填充-编写 Seeders
数据填充-使用模型工厂
数据填充-调用其他 Seeders
数据填充-禁用模型事件
数据填充-运行 Seeders
Eloquent-简介
Eloquent-生成模型类
Eloquent-Eloquent 模型约定
Eloquent-表名
Eloquent-主键
Eloquent-UUID 与 ULID 键
Eloquent-时间戳
Eloquent-数据库连接
Eloquent-默认属性值
Eloquent-严格配置 Eloquent
Eloquent-模型检索
Eloquent-集合
Eloquent-分块结果集
Eloquent-使用懒加载集合分块
Eloquent-游标
Eloquent-高级子查询
Eloquent-检索单个模型 / 聚合
Eloquent-检索或创建模型
Eloquent-检索聚合
Eloquent-新增 & 更新模型
Eloquent-新增
Eloquent-更新
Eloquent-批量任务
Eloquent-有则更新无则新增
Eloquent-删除模型
Eloquent-软删除
Eloquent-查询已被软删除模型
Eloquent-修剪模型
Eloquent-复制模型
Eloquent-查询作用域
Eloquent-全局作用域
Eloquent-局部作用域
Eloquent-模型对比
Eloquent-事件
Eloquent-使用闭包方法
Eloquent-观察者
Eloquent-静默事件
Eloquent: 关联
当前位置:
首页>>
技术小册>>
Laravel(10.x)从入门到精通(十七)
小册名称:Laravel(10.x)从入门到精通(十七)
### 数据库迁移-生成迁移 在Laravel框架中,数据库迁移(Migrations)是一种非常强大的特性,它允许你以一种版本控制的方式来定义和修改数据库结构。通过使用迁移,你可以很容易地在开发团队之间共享数据库结构的变更,同时也便于在不同的环境中(如开发环境、测试环境和生产环境)同步数据库结构。本章将深入介绍如何在Laravel 10.x中生成迁移文件,并理解其背后的基本概念和工作原理。 #### 一、迁移的基本概念 在Laravel中,迁移是一种描述数据库表结构的方式,它使用PHP代码来定义表的结构(如表名、字段、索引等)。每当你需要修改数据库结构时,你可以创建一个新的迁移文件来描述这些变更。Laravel的迁移系统通过时间戳来跟踪每个迁移的创建顺序,确保迁移可以按顺序被应用或回滚。 迁移文件通常位于`database/migrations`目录下,文件名遵循`YYYY_MM_DD_HHMMSS_create_xxx_table.php`的格式,其中`YYYY_MM_DD_HHMMSS`是创建迁移时的时间戳,`create_xxx_table`是对迁移内容的简短描述。 #### 二、生成迁移文件 在Laravel中,你可以使用Artisan命令行工具来快速生成迁移文件。Artisan是Laravel的命令行界面,它提供了许多有用的命令来帮助你进行开发。 ##### 1. 生成创建表的迁移 要生成一个用于创建新表的迁移文件,你可以使用`make:migration`命令,并指定迁移的名称。例如,如果你想创建一个名为`users`的表,你可以运行以下命令: ```bash php artisan make:migration create_users_table --create=users ``` 这里的`--create=users`选项告诉Artisan你想要创建一个名为`users`的新表。生成的迁移文件将包含创建该表的基本框架,包括一个`up`方法和一个`down`方法。`up`方法用于定义如何应用迁移(即如何创建表),而`down`方法则用于定义如何回滚迁移(即如何删除表)。 生成的迁移文件可能看起来像这样: ```php <?php use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\Schema; class CreateUsersTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::create('users', function (Blueprint $table) { $table->id(); $table->string('name'); $table->string('email')->unique(); $table->timestamp('email_verified_at')->nullable(); $table->string('password'); $table->rememberToken(); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('users'); } } ``` ##### 2. 生成修改表的迁移 如果你需要修改现有表的结构,比如添加、删除或修改字段,你可以不使用`--create`选项来生成迁移文件。生成的迁移文件将不包含`Schema::create`调用,但你可以使用`Schema::table`方法来指定要修改的表。 例如,要向`users`表添加一个`bio`字段,你可以运行: ```bash php artisan make:migration add_bio_to_users_table ``` 然后,在生成的迁移文件中,你可以这样编写`up`和`down`方法: ```php public function up() { Schema::table('users', function (Blueprint $table) { $table->text('bio')->nullable(); }); } public function down() { Schema::table('users', function (Blueprint $table) { $table->dropColumn('bio'); }); } ``` #### 三、迁移的工作原理 当你运行迁移时,Laravel会按照时间戳顺序执行`database/migrations`目录下的所有迁移文件。具体来说,它会查找尚未运行的迁移(即那些尚未在数据库迁移表中记录为已运行的迁移),然后按照时间戳顺序依次执行它们的`up`方法。 如果需要回滚迁移(比如,在部署前测试时),你可以使用Artisan的`migrate:rollback`命令。这将按照相反的顺序执行迁移的`down`方法,以撤销最近的迁移操作。 #### 四、最佳实践 - **保持迁移文件简洁**:尽量让每个迁移文件只负责一项变更,这有助于保持迁移的清晰和可维护性。 - **测试迁移**:在将迁移应用到生产环境之前,确保在开发或测试环境中彻底测试它们。 - **使用迁移来管理所有数据库结构变更**:无论变更大小,都尽量通过迁移来管理,这样可以避免手动修改数据库结构可能带来的问题。 - **定期审查迁移文件**:随着项目的发展,迁移文件可能会变得很多。定期审查并合并或删除不必要的迁移文件可以帮助保持项目的整洁。 #### 五、结论 数据库迁移是Laravel框架中一个非常强大的特性,它提供了一种优雅的方式来管理和同步数据库结构。通过掌握如何生成和应用迁移文件,你可以更高效地管理你的数据库结构,并确保你的应用在不同环境中保持一致的行为。希望本章内容能帮助你更好地理解和使用Laravel的迁移系统。
上一篇:
数据库迁移-介绍
下一篇:
数据库迁移-整合迁移
该分类下的相关小册推荐:
PHP8入门与项目实战(7)
PHP程序员面试笔试真题与解析
Shopify应用实战开发
PHP高性能框架-Workerman
PHP合辑4-字符串函数
Workerman高性能Web框架-Webman
PHP8入门与项目实战(1)
PHP合辑5-SPL标准库
Laravel(10.x)从入门到精通(一)
Swoole高性能框架-Hyperf
Laravel(10.x)从入门到精通(十三)
Yii2框架从入门到精通(中)