thinkphp5 migrate数据库迁移工具

 更新时间:2018年02月20日 10:26:46   作者:xueheo  
这里讲述的是tp5 migrate数据库迁移工具的相关介绍,非常的简单实用,有需要的小伙伴可以来看下本文的实例

tp5相对与tp3.2有很大的不同

migrate是其中一点,通过migrate程序员可以在php代码中创建数据库修改回滚等操作

首先下载migrate扩展,命令行到当前项目目录下执行

composer require topthink/think-migration

通过使用php think命令可以查看migrate是否成功下载

使用migrate:create migrate文件名(首字母大写的驼峰法),在database下生成migrate文件

有可能建立失败提示没有什么方法一般是composer获取的tp版本过低,考虑修改composer.json文件里的migrate的版本为1.*或^1.0

重新composer update即可

在application 下的 database.php 里配置好数据库

以下是其中一份migrate文件的内容(创建完后有一个默认方法change(),删除它)

 use think\migration\Migrator;
 use think\migration\db\Column;
 
 class CreateUserTable extends Migrator
 {
   
   /**
   * 建立用户表
   */
   public function up(){
     $table = $this->table('user');
     $table->addColumn('username' , 'string' , ['limit' => 30])
        ->addColumn('passwork' , 'string' , ['limit' => 32])
        ->addColumn('email' , 'string' , ['limit' => 25])
        ->addColumn('lastlogin_ip' , 'string' , ['limit' => 15])
        ->addTimestamps('create_time' , 'lastlogin_time')
        ->addColumn('status' , 'integer' , ['limit' => 1 , 'default' => 1])
        ->setId('user_id')
        ->save();
   }
   
   /**
   * 提供回滚的删除用户表方法
   */
   public function down(){
     $this->dropTable('user');
   }
 }

以上的一些方法 ,官方给予的文档我没看到在哪,网上我看的是小腾讲解的

使用migrate:run会执行所有的migrate的up方法

通过migrate:rollback可以回滚上一条执行的migrate文件(带 -t  0 参数回滚全部)

通过migrate:status可以查看当前migrate执行的情况

执行run方法后,user表建立成功

非常的方便

相关文章

  • ThinkPHP删除栏目(实现批量删除栏目)

    ThinkPHP删除栏目(实现批量删除栏目)

    下面小编就为大家带来一篇ThinkPHP删除栏目(实现批量删除栏目)。小编觉得挺不错的。现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 详解PHP的抽象类和抽象方法以及接口总结

    详解PHP的抽象类和抽象方法以及接口总结

    这篇文章主要介绍了PHP的抽象类和抽象方法以及接口总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • ThinkPHP采用模块和操作分析

    ThinkPHP采用模块和操作分析

    ThinkPHP采用模块和操作的方式来执行,首先,用户的请求会通过入口文件生成一个应用实例,应用控制器(我们称之为核心控制器)会管理整个用户执行的过程,并负责模块的调度和操作的执行,并且在最后销毁该应用实例。
    2011-04-04
  • PHP redis Sorted Set实现字符串去重代码示例

    PHP redis Sorted Set实现字符串去重代码示例

    Redis中的Sorted Set数据结构可以用来存储有序的唯一值,它们可以被用来构建有序的集合或者有权重的数据结构,下面这篇文章主要给大家介绍了关于PHP redis Sorted Set实现字符串去重的相关资料,需要的朋友可以参考下
    2023-05-05
  • PHP与Web页面交互操作实例分析

    PHP与Web页面交互操作实例分析

    这篇文章主要介绍了PHP与Web页面交互操作,结合实例形式分析了PHP与Web页面交互表单数据提交、特殊字符处理相关操作技巧,需要的朋友可以参考下
    2020-06-06
  • PHP中字符串长度的截取用法示例

    PHP中字符串长度的截取用法示例

    这篇文章主要介绍了PHP中字符串长度的截取用法,结合实例形式分析了mb_substr函数截取中文字符串的相关操作技巧与注意事项,需要的朋友可以参考下
    2017-01-01
  • PHP实现接收二进制流转换成图片的方法

    PHP实现接收二进制流转换成图片的方法

    这篇文章主要介绍了PHP实现接收二进制流转换成图片的方法,结合实例形式分析了php文件、目录及图形操作的相关技巧,需要的朋友可以参考下
    2017-01-01
  • PHP ajax 分页类代码

    PHP ajax 分页类代码

    不错的ajax分页类
    2008-11-11
  • php设计模式之单例模式实例分析

    php设计模式之单例模式实例分析

    这篇文章主要介绍了php设计模式之单例模式,实例分析了单例模式的原理与相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • phpstorm编辑器乱码问题解决

    phpstorm编辑器乱码问题解决

    这篇文章主要介绍了phpstorm编辑器乱码问题的解决方案,非常的实用,给需要的小伙伴们参考下。
    2014-12-12

最新评论