加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

Laravel框架数据库迁移的益处是什么?如何使用?

发布时间:2022-04-07 16:26:26 所属栏目:语言 来源:互联网
导读:在学习Laravel框架的时候,我们会接触到Laravel的数据库迁移,也叫做Migrations,很多新手对于为什么要数据库迁移以及好处不是很了解,对此,这篇文章就给大家介绍一下Migrations。 什么是 Migrations? 我们先来看一下Laravel官方文档怎么写的: Migrations
      在学习Laravel框架的时候,我们会接触到Laravel的数据库迁移,也叫做Migrations,很多新手对于为什么要数据库迁移以及好处不是很了解,对此,这篇文章就给大家介绍一下Migrations。
 
       什么是 Migrations?
       我们先来看一下Laravel官方文档怎么写的:
 
Migrations are like version control for your database, allowing your team to easily modify and share the application's database schema. Migrations are typically paired with Laravel's schema builder to easily build your application's database schema. If you have ever had to tell a teammate to manually add a column to their local database schema, you've faced the problem that database migrations solve.
 
       简单概括起来,就是我们可以将Migrations看作一种数据库的VCS(Version Control System),即版本控制系统。可以通过Laravel的artisan命令快速创建、修改或还原数据库结构。
 
       为什么要用 Migrations?
       使用Migrations可以有效地对数据库进行版本控制,并且遵从了Single Responsibility Principle(单一职责原则),更加方便数据库的操控。
 
       举个例子来说,假设我们已经设计并创建好了数据库,数据已经填充进数据库了,现在我们发现需要在其中一张表里增加一个名为name的栏目(column),需要在另一张表中将author栏目的名字改为user,那么我现在进入数据库里,进行了操作。刚刚操作完,公司老板突然找我面谈。面谈完了之后,我忘记了将我在数据库里的操作记录下来或者告知给其他开发人员,那么随之而来的很可能是灾难性的结果。
 
       如果我们使用了Migrations,并且只通过Migrations进行数据库的操作,那么所有开发人员都可以看到数据库进行了哪些操作,而不会发生上述的情况。
 
       Migrations 到底方便在哪里?
       除了上述提到的版本控制功能外,我们几乎不需要写SQL代码就能简单快速地组建起数据库结构,并且可以迅速迁移(migrate)或者回滚(Rollback),省去了大量人工操作的繁琐。讲解完了概念,我们现在来看一下具体怎么使用Migrations。
 
   * Reverse the migrations.        
   *        
   * @return void        
   */        
  public function down()        
  {        
    Schema::dropIfExists('samples');        
  }        
}
       我们看到,这个类中有up和down两个方法。up中我们需要添加创建数据表的函数,以及添加各个栏目的名称及属性。而down方法中我们需要添加在回滚该迁移文件时应该有什么样的结果(这里我们直接删除这张表)。
 
       可以看出,up和down中的操作是对应的,在up中进行了什么操作,down中就需要撤销这些操作。现在我们详细来看一下up方法。我们看到,Schema::create这个方法是用来创建我们数据表的,在方法中,我们看到Laravel已经为我们填充了几个columns。

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读