迁移类

迁移是一种结构化与有组织的方式来更改数据库的方便方法。你可以手动编辑 SQL 的片段,然后告知其他开发人员他们需要运行这些片段。你还得保持追踪他们的变化,追踪那些下次部署时那些需要运行但是会与生产设备冲突的变化。

数据库表的 迁移 追踪那些已经运行的迁移信息,你需要做的就是更新你的应用文件并执行 $this->migrate->current() 来计算出哪个迁移信息是需要被运行的。迁移信息的当前版本可以在这里 config/migration.php 找到。

创建一个迁移信息

这将是一个 blog 站点的第一个迁移信息。所有的迁移信息都在文件夹 application/migrations/ 里,并且具有这样的名称,例如:001_add_blog.php.

  1. defined('BASEPATH') OR exit('No direct script access allowed');
  2.  
  3. class Migration_Add_blog extends CI_Migration {
  4.  
  5. public function up()
  6. {
  7. $this->dbforge->add_field(array(
  8. 'blog_id' => array(
  9. 'type' => 'INT',
  10. 'constraint' => 5,
  11. 'unsigned' => TRUE,
  12. 'auto_increment' => TRUE
  13. ),
  14. 'blog_title' => array(
  15. 'type' => 'VARCHAR',
  16. 'constraint' => '100',
  17. ),
  18. 'blog_description' => array(
  19. 'type' => 'TEXT',
  20. 'null' => TRUE,
  21. ),
  22. ));
  23.  
  24. $this->dbforge->create_table('blog');
  25. }
  26.  
  27. public function down()
  28. {
  29. $this->dbforge->drop_table('blog');
  30. }

然后在文件 application/config/migration.php 中设置 $config['migration_version'] = 1;

使用范例

在该范例中,一些简单的代码被放置在 application/controllers/migrate.php 以更新架构(schema)。

  1. $this->load->library('migration');
  2.  
  3. if ( ! $this->migration->current())
  4. {
  5. show_error($this->migration->error_string());
  6. }

方法参考

$this->migration->current()

当前的迁移信息是什么,被设置于 $config['migration_version'] 在文件 application/config/migration.php 中。

$this->migration->latest()

这个方法的工作方式和 current() 很像,但是不会从 $config['migration_version'] 寻找迁移信息,而是在文件系统中寻找最新的迁移信息。

$this->migration->version()

迁移版本可以用来回滚或前进到特定版本。它工作起来像是 current() 但是会忽略 $config['migration_version'] 的设置。

  1. $this->load->library('migration');
  2.  
  3. $this->migration->version(5);

迁移参数

以下是迁移类的配置选项列表。

参数默认值可选项描述
migration_enabledFALSETRUE / FALSE启用或禁用迁移。
migration_version0当前数据库所使用的版本。
migration_pathAPPPATH.'migrations/'迁移信息所在路径。

翻译贡献者:csfhc, Hex, huboo