文档章节

PHP Migrations——Doctrine Migrations教程

小和
 小和
发布于 2016/09/02 13:32
字数 853
阅读 252
收藏 1

##PHP Migrations——Doctrine Migrations教程

博文链接 : http://my.oschina.net/u/930926/blog/741477

版权声明:本文为博主原创文章,未经博主允许不得转载。

Doctrine Migrations github地址:https://github.com/doctrine/migrations

不知道Migrations有什么用,可参考这篇文章:为什么要用PHP Migrations

官方文档Getting Started(快速开始)写得非常不好,用CodeIgniter集成Migrations代码,做了快速演示Demo,可以先把代码跑起来,再看搭建笔记。

本教程需要使用Composer,既然是趋势就早日拥抱,能写PHP的这点工具用不来说不过去
如果对Composer还不了解,请参考 Composer中文网

快速演示Demo

  1. 克隆代码到本地,本地Mysql新建ci数据库,可参考application/config/database_config.php配置文件
  2. 用composer把migration相应包更新下来,composer update
  3. 切换到script/migration目录,测试migration,php migrations.php,命令说明参考搭建笔记的测试命令

搭建笔记

用CodeIgniter 3.x来举例集成Doctrine Migrations

1. 使用 Composer 安装 doctrine/migrations和symfony/console

如果对Composer还不了解,请参考 Composer中文网

composer require doctrine/migrations
composer require symfony/console:~2.5

symfony/console最新的3.x版本已经弃用了Symfony\Component\Console\Helper\HelperSet,所以要指定安装symfony/console:~2.5版本

2. 构建script/migration目录

  • application/config/目录创建公用的数据配置文件database_config.php,database.php使用该配置,migrations也使用该配置
  • 复制script/migration目录来用,migrations.php部分代码是连接数据库,具体不详细说了,自行看源码,可参考官方文档

3. 测试Migrations命令

  • 列举所有命令

      php migrations.php
    

  • 创建Migrations脚本文件

       sh gen.sh 或 php migrations.php migrations:generate
    

在新创建的php文件,添加数据库sql语句 文件中自动创建了 updown 两个方法

up 方法是执行Migrations脚本自动执行的函数

down 方法是执行Migrations脚本up函数出错后,回滚执行的函数

在两个方法加入sql,具体可以参考官方的文档,也可以用ORM来编写

  • 执行Migrations脚本文件

      sh mig.sh 或 php migrations.php migrations:migrate
    

因为 config/migrantions.yml 定义 migration_versions 表记录执行过Migrations文件,所以migrations:migrate命令会检查migration_versions表,判断哪些Migrations文件没执行,再执行。

4. 简化命令

常用2个命令:php migrations.php migrations:generatephp migrations.php migrations:migrate ,可是有没有觉得这两个命令好长,写两个sh文件来简化命令,所以在migration目录有mig.sh和gen.sh文件,使用sh gen.shsh mig.sh ,就简单很多了。

  • mig.sh

      #!/bin/sh
      cd  $(cd `dirname $0`;pwd) # 切换到当前目录
      php migrations.php migrations:migrate
    
  • gen.sh

      #!/bin/sh
      cd  $(cd `dirname $0`;pwd) # 切换到当前目录
      php migrations.php migrations:generate
    

sh脚本文件最好用vi编写或者保存unix编码,不然会报以下错误:

[Symfony\Component\Console\Exception\CommandNotFoundException]  
" is not defined.                   
  Did you mean one of these?                                      
      migrations:migrate                                          
      migrations:status                                           
      migrations:execute                                          
      migrations:generate                                         
      migrations:version                                          
      migrations:diff   

可以用dos2unix mig.sh命令转换文件编码

没有dos2unix命令,可以 sudo apt-get install dos2unix 安装

最后,感觉这样的搭建方式还是有点繁琐,有兴趣的同学可以尝试用PHAR文件,再用sh脚本封装一下或许简单很多。

若有哪里不清楚,可以参考github上的代码,也可以留言。

https://github.com/lyaohe/ci-migration

参考资料

© 著作权归作者所有

小和
粉丝 7
博文 24
码字总数 7978
作品 0
广州
私信 提问
为什么要用PHP Migrations

曾经也思考过,代码管理可以用代码版本控制git、svn来协同,怎么数据库字段就不能用git、svn来同步? 后来在团队开发中认识到Migrations数据库迁移工具,我的理解是【数据库字段同步工具】,...

小和
2016/09/02
29
0
CodeIgniter 3.0.6 发布,PHP 的 MVC 框架

CodeIgniter 3.0.6 发布了。 改进日志: General Changes Added a destructor to Cache Library ‘memcached’ driver to ensure that Memcache(d) connections are properly closed. Depre......

oschina
2016/03/22
1K
11
Laravel4.1数据库 数据库迁移案例(四)

创建迁移 首先,让我们创建一个MySql数据库“Laravel_db”。接下来打开app/config目录下的database.php文件。请确保default键值是mysql: 1 return array(2 ...3 'default' => 'mysql', 然后输......

botkenni
2016/11/16
3
0
.net core EF 命令

http://www.bsjobjob.com 璧山人才网,璧山招聘网 https://docs.microsoft.com/zh-cn/ef/core/what-is-new/ef-core-2.0 ef 命令 https://github.com/aspnet/EntityFrameworkCore 开源地址 .n......

phantasy
2017/06/29
0
0
EF Core 迁移过程遇到EF Core tools version版本不相符的解决方案

如果你使用命令: PM> add-migration Inital 提示如下信息时: The EF Core tools version '2.1.1-rtm-30846' is older than that of the runtime '2.1.4-rtm-31024' 解决方法大致一下几种:......

duanyong
2018/11/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

ubuntu或ubuntu kylin优麒麟中安装QQ、wechat微信、百度网盘

从中国国内的地址下载deepin wine,码云上的。这样网速比较快。然后,按照说明向下安装。 https://gitee.com/wszqkzqk/deepin-wine-for-ubuntu...

gugudu
34分钟前
2
0
基于redis分布式锁实现“秒杀”

最近在项目中遇到了类似“秒杀”的业务场景,在本篇博客中,我将用一个非常简单的demo,阐述实现所谓“秒杀”的基本思路。 业务场景 所谓秒杀,从业务角度看,是短时间内多个用户“争抢”资源...

别打我会飞
54分钟前
14
0
Zookeeper的实践指南

本章重点 1.数据存储2.基于Java API初探Zookeeper的使用3.深入分析Watcher机制的实现原理4.Curator客户端的使用,简单高效 数据存储 事务日志快照日志运行时日志 bin/zookeepe...

须臾之余
57分钟前
2
0
MySQL mybatis Point类型数据

MySQL中的point用于表示GIS中的地理坐标,在GIS中广泛使用 如何写入mysql,如下图: CREATE TABLE `test-point` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '序号', `point` ......

张欢19933
今天
3
0
设计模式-适配器模式

适配器模式 适配器模式(Adapter Pattern)是作为两个不兼容的接口之间的桥梁。这种类型的设计模式属于结构型模式,它结合了两个独立接口的功能。 这种模式涉及到一个单一的类,该类负责加入...

HOT_POT
今天
20
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部