开发人员:Ruby on Rails
Ruby on Rails 之 Oracle 应用:简易教程作者:Richard Monson-Haefel(包含 Jesse Hu 对 Rails 2.3 和 ActiveRecord Oracle 增强适配器所做的修改) Rails 是一个易于使用的框架,但它和其他技术一样,需要花费一定时间方可掌握。
2009 年 4 月更新 有关本文的评论?请访问 Ruby/RoR 论坛 您可能听说过 Ruby on Rails,一个似乎正以狂风暴雨之势席卷 Web 开发社区(尤其是 JEE 和 PHP 的编程人员)的新应用框架。 Rails 是功能强大的 Web 应用平台,而且深受 JEE 和 PHP 的编程人员的喜爱。当您了解了 Rails 的优势后,您就会理解它为何对 J2EE 和 PHP 编程人员有如此的吸引力。首先,它使用任何自视甚高的设计模式专家都很钦佩的严格的模型-视图-控制器体系结构;这可以解释它为什么吸引了大量 JEE 开发人员。其次,使用 Rails 可以轻松地构建基本系统 — 这对 PHP 开发人员具有吸引力。 然而,从数据库的角度来说,Rails 还是有一些非常大的局限性。Rails 对您的数据库布局和应用程序需求做出了许多假定。例如,Rails 假定所有表都使用单一的非组合式主键。需通过 Rails 插件支持组合式主键。此外,Rails 支持多数据库而且可以对其间事务进行协调;Rails 不支持两阶段提交。 本文章的目的不在于对 Rails 进行赞扬或批评,而只是对该技术的介绍。其中包含表扬也包含有批评。有时批评可能看起来过重了(尤其对于那些 Rails 的热爱者来说),但是请不要将 Rails 看得神乎其神。使用任何 Web 应用框架都是需要技巧的,无论是 JEE、ASP.NET 还是 PHP。从长远来看,使用 Rails 可能比使用许多其他 Web 应用程序开发平台更高效,但是也需要假以时日来学习其中的技巧。 Ruby 是什么?Rails 是什么?Ruby 是一种动态编程语言,在很多方面和 Perl、Python 以及 Smalltalk 相似,但也有自己的特点。Java 和 PHP 编程人员似乎可以非常轻松地学会该语言,而且他们是 Ruby 的最忠实的拥护者。但是其他人也为该语言所吸引;这其中还包括著名的 Microsoft 王国中最资深的专家之一 Don Box。 Ruby 并不是新生事物;它创建于 1993 年,时间比 1995 年发布的 Java 或 PHP 都要久。当时 Ruby 语言虽已成熟,但不如某些其他语言受欢迎。因此,Ruby 编程语言的周边体系并不像 Java、PHP 或 Perl 那样丰富。因此,您能找到的有关该语言的框架、信息库、书籍、Web 站点、网志和其他资源也相对较少。 David Heinemeier Hanson 提出了 Rails 框架(Ruby 历史上最受欢迎的应用程序)后,Ruby 社区的软弱无力的市场表现近期发生了变化。Rails 将 Ruby 编程语言扩展为域特定的语言,特别适合 Web 开发。它还使用了另一种语言扩展 ActiveRecord,使 Ruby 具有对象关系持久性。除了不支持组合主键和两阶段提交外,使用 Rails 的最大障碍是您需要学习一种新的编程语言。这对大多数人来说都是不可忽视的问题;学习新语言是一项有趣的但令人望而却步的任务。 然而,如果您希望学习更多语言,我想没有别的语言比 Ruby 更值得推荐了。Ruby 代表着 10 年无商业利益篡改开发的巅峰。因此,Ruby 是受欢迎的语言,而且在很多情况下比 Java、C、或 Microsoft .NET 语言更高效。(可能要排除 Microsoft .NET 环境的 Python 语言端口 IronPython。Python,像 Ruby 一样,是一种动态高效的编程语言。) Rails 的用途Rails 的设计初衷是创建使用关系数据库后端的动态 Web 站点。它将关键词添加到 Ruby 编程语言中,从而使 Web 应用程序更易于配置。此外,它还可以从现有的数据库模式中自动生成完整(如果有些粗略)的 Web 应用程序。后者既是 Ruby 的最大优点也是它的致命缺点。Rails 对数据库模式命名惯例做出了假设,如遵循这些假设,只需执行一个命令即可生成一个基础 Web 站点。但是要完成此操作需要额外的配置,在一些情况下,则是根本无法实现的。您还可能发现 Rails 期望的每一个数据库惯例都可以被覆盖,但是需要做的覆盖越多,平台的效率就越低。这就是为什么 Rails 在使用新数据库开发“绿色领域”应用程序时非常强大的原因。不幸的是,它在处理原有系统时并不是一个很好的解决方案。 要展示 Rails 在绿色领域应用程序开发中的作用,最好的方法是通过示例。如果您已经安装了 Oracle 数据库,并可以在其中创建新的数据库和表,那么创建一个完整的 Web 应用程序只需不到 15 分钟的时间。在这种情况下,我们将使用 Ruby of Rails 来构建一个产品目录。 示例:简单产品目录2005 年,我开始投资于高级 (HG) 漫画书,特别是 1946 年以来的旧书。我创建了一个简单的 Ruby on Rails 数据库应用程序,这样我可以随着新漫画书的买入和卖出对其进行插入、移动、修改和删除。由于仅供我个人使用,所以我将它做得特别简单。本文即将开发的应用程序是我在家使用的 Ruby on Rails 应用程序的删节版。 虽然 Rails 和 Oracle 数据库可以应用于多种平台,但本文中将侧重于 Oracle 应用程序开发人员最常使用的操作系统之一 Windows XP。本示例非常简单;基本上是等同于“Hello World”编程语言示例的数据库。这只是为了让您简单了解一下 Ruby,而并不展示 Rails 的全部功能,至多只是个用于演示任意编程语言完整功能的“Hello World”示例。 如果您在本示例中遇到问题,可能是以下三种原因之一引起的:不是您下载了错误的代码,就是您的数据库没有设置为允许连接,再或者就是您的 Windows XP 操作系统的问题。在开发本示例的过程中,我遇到了一些版本控制和数据库配置的相关问题 — 都是由于无知造成的。多亏了我的一个朋友 Michael Carland,我才能完成此示例并让本示例尽可能简单。 事实是,让 Ruby on Rails 和 Oracle 协同工作并不简单。实际上,有时还可能有点令人沮丧。严格按照本文说明执行,您应该不会遇到问题。但是,如果超出了本示例范围,可能会出现一些问题。Rails 可以非常高效,但它是一个命令行开发环境,而且不附带通常与高级集成开发环境相关联的“自动魔术”。如果您不是一个“自己动手做”的技术人员,那我这次将不会向您推荐 Rails。 第 1 步:设置 Oracle 数据库如果您不是对结合 Oracle 使用 Rails 感兴趣,您不会阅读本文。所以您需要安装一个 Oracle 数据库实例并为此示例 Rails 应用程序创建一个模式。执行此操作最简单的方法是使用 SQL*Plus,如下所示。(假定您已经安装 Oracle 数据库并知道如何使用。本教程中使用 Oracle 数据库 11g 。) 使用 SQL*Plus,创建一个可用于本应用程序的用户。 SQL> GRANT CONNECT, RESOURCE TO ruby IDENTIFIED BY ruby;
如果您使用远程 Oracle 数据库,您需要安装 Oracle 数据库即时客户端,这样您无需安装标准 Oracle 客户端也无需拥有 ORACLE_HOME 即可运行您的应用程序。要安装该软件,请执行以下步骤:
要在 Windows XP 上使用 Rails,您需要两套软件:带有 RubyGems 安装包的 Ruby 编程语言 Rails 2.3.2(Rails 的最新版本)和 Ruby/Rails Oracle 数据库。要下载并安装带有 Gems 安装包的 Ruby 安装程序,请执行以下步骤:
当 Ruby 编程平台安装完毕后,您就可以使用 RubyGems 了。RubyGems 是一个 Ruby 应用程序,您可以利用它来轻松安装 Ruby 框架。要安装 Rails 应用开发框架,您首先需要更新 Rubygems,因为 Rails 2.3.2 要求使用 Rubygems 1.3.1(或更高版本): C:\> gem update --system
然后安装 Rails: C:\> gem install rails -v 2.3.2
既然您已经安装了 Ruby、RubyGems 和 Rails,您现在可以安装特定代码库,以使您的 Ruby/Rails 应用程序可以与您的 Oracle 数据库服务器进行通信。要安装 Ruby Oracle 库和 ActiveRecord Oracle Adapter,执行以下命令:
C:\> gem install ruby-oci8 -v 1.0.4
C:\> gem install activerecord-oracle-adapter --source http://gems.rubyonrails.org
ActiveRecord Oracle Adapter 的另一个选择是 Oracle ACE Raimonds Simanovskis 维护的倍受欢迎的 ActiveRecord Oracle 增强适配器。该适配器包含可用于新的和原有的 Oracle 数据库的有用的其他特性,这些特性从实际项目针对原始 ActiveRecord Oracle 适配器 (activerecord-oracle-adapter) 的补丁提取而来,并支持三个主要的 Ruby 解释器(MRI 1.8.6、JRuby 1.1.6 和 Ruby/YARV 1.9.1)。要安装 ActiveRecord Oracle 增强适配器,执行以下命令: C:\> gem install activerecord-oracle_enhanced-adapter 假设一切顺利,您现在已经安装了 Ruby、Rails 和 Rails-Oracle 连接库。现在,您可以创建您的第一个 Ruby on Rails Web 应用程序了。 第 3 步:创建 Web 应用程序要创建新 Rails 应用程序,您需要按照如下所示创建一个新 Rails 项目。 使用 rails 命令行应用程序创建一个新项目(这将自动创建一个新目录)。 C:\> rails comics_catalog -d oracle
转至在前面步骤中创建的新项目目录。 C:\> cd comics_catalog
既然您已创建一个新的 Rails 项目目录,现在您将需要配置您的项目以便 Rails 应用程序将使用 Rails-Oracle 连接库。 在您的项目目录中,有一个名为 config 的目录,其中有一个名为 database.yml 的文件。您需要使用您最喜爱的文本编辑器编辑 database.yml。最初,该文件将如下所示: development:
不同的数据库需要不同的连接属性。Rails 默认设置为使用 MySQL,但是您希望重新配置该项目以使用 Oracle。按照该 Oracle on Rails wiki 页面上的说明更改开发属性。(您可能还更改测试和生产属性,但是本文不讨论测试或生产版本。)当在远程设备上使用 Oracle 数据库时,文件将如下所示: development:
如果使用 ActiveRecord Oracle 增强适配器,请将“oracle_enhanced”而不是“oracle”指定为适配器。 在 Rails 中创建 Web 应用程序有很多种方法,但是目前最简单的方法是使用 scaffold,这是一个可以在 Rails 中使用单一命令构建整个应用程序的命令行特性。 C:\comics_catalog> ruby script/generate scaffold comic title:string issue:integer publisher:string
这里的“title:string”代表 Rails 中类型为“string”的表列,与 Oracle 中的“varchar2”类型相对应。 没有命令窗口中的一系列输出,那么刚才发生了什么?Rails 代码生成器创建了模型、视图和控制器 Ruby 代码以访问 COMICS 表。在本示例中,您创建应用程序所使用的 Rails scaffold 已经为您做了所有的工作。 如果您对数据库表做出任何改动,您将需要再次运行 scaffold 命令。否则,您的应用程序可能不会工作。 您还没有创建任何数据库表。Rails 可以帮助您轻松完成,执行下列命令即可创建“comics”表: C:\comics_catalog> rake db:migrate
既然 Web 应用程序已经生成,现在您可以启动 Ruby Web 服务器 WEBrick。 C:\comics_catalog> ruby script/server
您可以随时更改您应用程序的 Ruby 代码,无需重新启动 web 服务器。然而,如果您更改数据库配置文件(例如 database.yml),您将需要重新启动服务器。 现在,您可以在您自己的开发设备上使用您最喜爱的 Web 浏览器访问您的 Rails Comic Catalog 应用程序了。只需访问以下 URL。 您的浏览器将如图 1 所示一样显示您的 Catalog 中的漫画书列表。 图 1:产品目录列表 当您使用 scaffold 创建 Rails Web 应用程序时,它将自动创建三个 Web 组件,从而使您能够看到目标数据库表中所有记录的列表,并对表中的记录进行插入、修改和删除的操作。图 1 显示了示例数据列表。 除了 Listing 视图,还有详细信息视图。只需单击任意“Show”链接即可查看专门显示该特定记录中数据的 Web 页面。图 2 是该详细信息页面的示例。 图 2: 详细信息页面 您还可以在数据库表中编辑任何记录。单击“Back”链接,或使用您的浏览器“返回”按钮返回到 Listing 页面,然后单击任意记录的“Edit”链接。图 3 展示了 COMICS 数据库表中的一个记录的 Editing 视图示例。 图 3: Editing 视图 您也可以通过返回 Listing 视图并单击“New Comic”链接来向 COMICS 表中添加新记录。您所见的视图将与图 3 中所示相似,只是域中都将为空白。 精通 Rails虽然产品目录示例展示了使用 Rails 创建一个简单应用程序是多么容易,但它在跟踪库存以外的其他方面并不是如此有效。您可以使用 Rails 创建更为复杂的 Web 应用程序,但是那将需要您进行编码操作,并且需要学习。Rails 是一个易于使用的框架,但它和其他技术一样,需要花费一定时间方可掌握。 要真正精通 Rails,您应该阅读一本书,也许今年晚些时候会有很多相关书籍,但是现有的非常好的一本是 David Heninmier Hanson 和 Dave Thomas 所著的《Agile Web Programming with Ruby on Rails》 (Pragmatic Bookshelf 2005 年出版)。Hanson 是 Rails 的创始人,而 Thomas 是《Programming Ruby: The Pragmatic Programmers' Guide》 (Pragmatic Bookshelf;第二版,2004 年)的作者之一。 另请参见:Rails 上的 HR 模式,了解创建可利用旧模式的 Ruby on Rails Web 应用程序的技巧。 另请参见:结合使用 Oracle 和 Ruby on Rails ,学习如何使用 Oracle 安装 Ruby/Rails,以及如何开发高效且功能强大的 Ruby/Rails 应用程序。 Richard Monson-Haefel (http://www.monson-haefel.com/) 是 CSG 高级资深架构师,著有《Enterprise JavaBeans》 (O'Reilly,2004)、《J2EE Web Services》 (Addison-Wesley,2003)和《Java Message Service》 (O'Reilly,2000)。他是 Apache J2EE 应用服务器项目 (Geronimo) 以及 OpenEJB 项目的创建者。 Jesse Hu (jersey.hu@oracle.com) 是一名面向技术人员的开发人员,就职于 Oracle 亚洲研发中心。 |