Laravel 5框架学习之数据库迁移(Migrations)


Posted in PHP onApril 08, 2015

database migrations 是laravel最强大的功能之一。数据库迁移可以理解为数据库的版本控制器。

在 database/migrations 目录中包含两个迁移文件,一个建立用户表,一个用于用户密码重置。

在迁移文件中,up 方法用于创建数据表,down方法用于回滚,也就是删除数据表。

执行数据库迁移

php artisan migrate

#输出

Migration table created successfully.

Migrated: 2014_10_12_000000_create_users_table

Migrated: 2014_10_12_100000_create_password_resets_table

查看mysql数据库,可以看到产生了三张表。 migratoins 表是迁移记录表,users 和 pasword_resets。

如果设计有问题,执行数据库回滚

php artisan migrate:rollback

#输出

Rolled back: 2014_10_12_100000_create_password_resets_table

Rolled back: 2014_10_12_000000_create_users_table

再次查看mysql数据库,就剩下 migrations 表了, users password_resets 被删除了。

修改迁移文件,再次执行迁移。

新建迁移

php artisan make:migration create_article_table --create='articles'

#输出

Created Migration: 2015_03_28_050138_create_article_table

在 database/migrations 下生成了新的文件。

<?php

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateArticleTable extends Migration {

 /**
 * Run the migrations.
 *
 * @return void
 */
 public function up()
 {
 Schema::create('articles', function(Blueprint $table)
 {
  $table->increments('id');
  $table->timestamps();
 });
 }

 /**
 * Reverse the migrations.
 *
 * @return void
 */
 public function down()
 {
 Schema::drop('articles');
 }

}

自动添加了 id列,自动增长,timestamps() 会自动产生 created_at 和 updated_at 两个时间列。我们添加一些字段:

public function up()
 {
 Schema::create('articles', function(Blueprint $table)
 {
  $table->increments('id');
      $table->string('title');
      $table->text('body');
      $table->timestamp('published_at');
  $table->timestamps();
 });
 }

执行迁移:

php artisan migrate

现在有了新的数据表了。

假设我们需要添加一个新的字段,你可以回滚,然后修改迁移文件,再次执行迁移,或者可以直接新建一个迁移文件

php artisan make:migration add_excerpt_to_articels_table

查看新产生的迁移文件

<?php

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class AddExcerptToArticelsTable extends Migration {

 /**
 * Run the migrations.
 *
 * @return void
 */
 public function up()
 {
 //
 }

 /**
 * Reverse the migrations.
 *
 * @return void
 */
 public function down()
 {
 //
 }

}

只有空的 up 和 down 方法。我们可以手工添加代码,或者我们让laravel为我们生成基础代码。删除这个文件,重新生成迁移文件,注意添加参数:

php artisan make:migration add_excerpt_to_articels_table --table='articles'

现在,up 方法里面有了初始代码。

public function up()
 {
 Schema::table('articles', function(Blueprint $table)
 {
  //
 });
 }

添加实际的数据修改代码:

public function up()
 {
 Schema::table('articles', function(Blueprint $table)
 {
  $table->text('excerpt')->nullable();
 });
 }
 
 public function down()
 {
 Schema::table('articles', function(Blueprint $table)
 {
  $table->dropColumn('excerpt');
 });
 }

nullable() 表示字段也可以为空。

再次执行迁移并检查数据库。

如果我们为了好玩,执行回滚

php artisan migrate:rollback

excerpt 列没有了。

以上所述就是本文的全部内容了,希望能够给大家熟练掌握Laravel5框架有所帮助。

PHP 相关文章推荐
php 购物车实例(申精)
May 11 PHP
解析coreseek for sphinx的使用
Jun 21 PHP
页面乱码问题的根源及其分析
Aug 09 PHP
使用php检测用户当前使用的浏览器是否为IE浏览器
Dec 03 PHP
PHP制作图形验证码代码分享
Oct 23 PHP
PHP7+Nginx的配置与安装教程详解
May 10 PHP
php 截取utf-8格式的字符串实例代码
Oct 30 PHP
常用PHP封装分页工具类
Jan 14 PHP
thinkPHP框架实现的简单计算器示例
Dec 07 PHP
PHP获取对象属性的三种方法实例分析
Jan 03 PHP
Yii Framework框架使用PHPExcel组件的方法示例
Jul 24 PHP
laravel 出现command not found问题的解决方案
Oct 23 PHP
Laravel 5框架学习之环境与配置
Apr 08 #PHP
Laravel 5框架学习之Blade 简介
Apr 08 #PHP
Laravel 5框架学习之向视图传送数据(进阶篇)
Apr 08 #PHP
Laravel 5框架学习之向视图传送数据
Apr 08 #PHP
Laravel 5框架学习之路由、控制器和视图简介
Apr 07 #PHP
Laravel 5框架学习之Laravel入门和新建项目
Apr 07 #PHP
php生成圆角图片的方法
Apr 07 #PHP
You might like
别人整理的服务器变量:$_SERVER
2006/10/20 PHP
单点登录 Ucenter示例分析
2013/10/29 PHP
php中的filesystem文件系统函数介绍及使用示例
2014/02/13 PHP
Codeigniter生成Excel文档的简单方法
2014/06/12 PHP
PHP封装的字符串加密解密函数
2015/12/18 PHP
php面试中关于面向对象的相关问题
2019/02/13 PHP
关于JavaScript的面向对象和继承有利新手学习
2013/01/11 Javascript
jquery和雅虎的yql服务实现天气预报服务示例
2014/02/08 Javascript
confirm的用法示例用于按钮操作时确定是否执行
2014/06/19 Javascript
jquery带有索引按钮且自动轮播切换特效代码分享
2015/09/15 Javascript
基于javascript实现窗口抖动效果
2016/01/03 Javascript
DIV随滚动条滚动而滚动的实现代码【推荐】
2016/04/12 Javascript
js中scrollTop()方法和scroll()方法用法示例
2016/10/03 Javascript
完美解决spring websocket自动断开连接再创建引发的问题
2017/03/02 Javascript
Node.js环境下Koa2添加travis ci持续集成工具的方法
2017/06/19 Javascript
Vue2几种常见开局方式详解
2017/09/09 Javascript
React-intl 实现多语言的示例代码
2017/11/03 Javascript
Angular 实现输入框中显示文章标签的实例代码
2018/11/07 Javascript
[03:15]2014DOTA2国际邀请赛 专访国士无双信心满满
2014/07/12 DOTA
Python基于csv模块实现读取与写入csv数据的方法
2018/01/18 Python
python分治法求二维数组局部峰值方法
2018/04/03 Python
Python中XlsxWriter模块简介与用法分析
2018/04/24 Python
Django框架 Pagination分页实现代码实例
2019/09/04 Python
python 实现图片上传接口开发 并生成可以访问的图片url
2019/12/18 Python
简单了解python装饰器原理及使用方法
2019/12/18 Python
Tensorflow的常用矩阵生成方式
2020/01/04 Python
Tensorflow 卷积的梯度反向传播过程
2020/02/10 Python
css3 边框、背景、文本效果的实现代码
2018/03/21 HTML / CSS
简单的HTML5初步入门教程
2015/09/29 HTML / CSS
浅谈HTML5中dialog元素尝鲜
2018/10/15 HTML / CSS
String是最基本的数据类型吗?
2013/06/13 面试题
大学生自助营养快餐店创业计划书
2014/01/13 职场文书
无违反计划生育证明格式
2015/06/24 职场文书
消夏晚会主持词
2015/06/30 职场文书
Nginx工作原理和优化总结。
2021/04/02 Servers
漫画「你在春天醒来」第10卷封面公开
2022/03/21 日漫