技术开发 频道

使用Rails的数据迁移管理MySQL数据库

IT168 技术文档】在过去的十几年中,我曾经创建和管理了不下百个MySQL数据库,在这个过程中我曾使用各种工具来使管理它的过程更简单,例如首选的图形化管理工具PHPMyAdmin,以及基于命令行的MySQL clent,它们都非常好用。但是在我内心身处始终觉得,我是一个程序员,而不是一个数据库管理员,总感觉编程和数据库管理之间有些跨越。为什么不用与编程相同的方式来管理数据库结构呢?我的这种梦想一直没有实现,不过自从开始使用Rails,我找到了答案。通过Rails的数据迁移(migration)功能,我可以使用程序员的方式来管理MySQL数据库了。

   数据迁移功能让你可以使用Ruby语言来管理你的数据库方案,你可以充分利用一些Ruby所特有的工具,诸如Rake,来根据Ruby脚本提供的指令来更新数据库。还有,数据迁移功能还具有一个内置的版本控制功能,让你可以像在Subversion或CVS中那样对所做的修改进行前后的回滚。听起来是不是很具有诱惑力呢?在本篇文章中,我将介绍给你几个关键的数据迁移概念,并且告诉你如何才能比以前更高效的管理你的MySQL数据库。

   从头开始,首先创建一个新的Rails项目,并将其命名为addresbook:

%>rails addressbook

创建数据库

   接下来需要做的是针对一个应用程序的开发周期来创建Rails需要的数据库,我们这儿用的是addressbook_development、addressbook_test和addressbook_production:

mysql> create database addressbook_development; Query OK, 1 row affected (0.00 sec) mysql> create database addressbook_test; Query OK, 1 row affected (0.00 sec) mysql> create database addressbook_production; Query OK, 1 row affected (0.00 sec)

   最后,为了让Rails能够与这个数据库进行会话,打开这个应用程序的database.yml文件,并修改其中的authorization参数。因为在这篇文章中我只是使用了addressbook_development数据库,因此只需在database.yml文件中的development加入以下内容:

development: adapter: mysql database: addressbook_development username: addressbook_user password: secret host: localhost

   完成以上工作后,你就可以开始使用它的数据移植功能了。

0
相关文章