去年的时候,用rails 1.2.3做过一些在oracle方面的应用. 后来, rails2.0出来后,数据库一直使用着mysql. 这两天又需要在oracle上使用, 于是开始在将rails2.0.2升级在oracle上. 没想到,麻烦的事情还真不少.
常规的升级
2.0版本以后,商业数据库的adapter被移出了核心,现在新的商业数据库的adapter都遵循activerecord-XYZ-adapter
的命名规则,也就是activerecord-oracle-adapter.
所以需要安装:
- 适配器(adapter)
- gem install
activerecord-oracle-adapter --source http://gems.rubyonrails.org
- ruby-oci8驱动
- gem install ruby-oci8 或者 ruby ruby-oci8-1.0.0-mswin32.rb
之后的麻烦
按有些地方提示,把yml文件里面的adapter: oci改成adapter: oracle,以为就能工作了. 但结果很令人失望, 老是报一条TNS的错误.
令人不甘心的解决办法
反复google之后,发现有人建议把 E:\InstantRails-2.0-win\ruby\lib\ruby\gems\1.8\gems\activerecord-oracle-adapter-1.0.0.9216\lib\active_record\connection_adapters下面的oracle_adapter.rb改名成oci.rb,并且把adapter再次改回成oci. 一试之下,这招能够奏效. 之后运行迁移任务等都变得正常.
终于冲了出来
虽然能这么用了,但实在不相信以TDD标榜的rails会留下这么大的一个bug,上面那个解决办法实在让人不甘心.
隔天再来总算发现了问题所在.
因为之前已经有了一个针对oracle的应用,于是yml里的配置文件是copy而来. 写法如下:
oracle:
adapter: oracle
username: e
password: e
host: 10.11.16.63/
只不过把中间的oci换成了oracle,而实际上rails2.0中把yml的配置项也adapter化了,即所有的数据库的配置用统一的方式来处理,上面的host变成了和mysql等中一样的database,新的写法如下:
oracle:
adapter: oracle
username: e
password: e
database: //10.11.16.63/e
这样的话,所有的情况都很正常.
关键不是在于哪种配法解决问题, 而是对rails的测试程序的信任和信心. 毕竟我对rails和tdd的好处都有信心.
而rails统一adapter的做法也不能说不好,不过确实增加了升级的麻烦, 文档的支持也少了些.
http://soft.chinabyte.com/293/7782793.shtml
分享到:
相关推荐
《jRuby on Rails WEB2.0》:将Ruby on Rails融入Java平台的实践指南 《jRuby on Rails WEB2.0》是一部由Ola Bini撰写的书籍,深入探讨了如何将Ruby on Rails这一敏捷开源框架与Java平台相结合,以构建高效、灵活的...
### Rails 2.0 的配置方法 #### 一、引言 Rails 2.0作为Ruby on Rails(简称ROR)框架的一个重要版本,在Web开发领域具有不可忽视的地位。本篇将详细介绍Rails 2.0的配置过程及注意事项,帮助初学者快速上手并深入...
《JRuby on Rails Web 2.0 实用项目》 英文PDF + 源码
Rails 2.0 API 文档是一个非常宝贵的资源,它为开发者提供了全面的指南,以便于在使用Ruby on Rails 2.0版本时更好地理解和利用其框架功能。Ruby on Rails(简称Rails)是一个开源的Web应用框架,它遵循MVC(模型-...
这个“ruby on rails2.0本地安装包”适用于Windows和Linux操作系统,特别是针对网络速度较慢的用户设计,方便他们离线安装Rails 2.0.2版本。 在Rails 2.0版本中,有几个关键性的改进和特性: 1. **ActiveRecord**...
总体来说,Rails 2.0虽然没有带来革命性的变化,但它通过一系列小幅度的改进和优化,提升了开发效率,增强了系统的稳定性和安全性。对于正在使用Rails进行Web开发的团队来说,了解这些新特性是非常有价值的。
Rails以其快速的版本迭代和创新的功能而闻名,从1.0到2.0的升级也不例外。这次更新带来了许多新特性,提升了开发效率和用户体验。 首先,Rails 2.0 对RESTful架构进行了深入优化。REST(Representational State ...
### JRuby on Rails Web 2.0 Projects:将Ruby on Rails引入Java平台 #### JRuby简介 JRuby是一种Ruby语言的实现,它运行在Java平台上,利用了Java虚拟机(JVM)的强大功能。JRuby使得开发人员能够在Java环境中使用...
总之,要使Rails 2.1应用与Oracle数据库成功连接,你需要正确安装和配置Oracle数据库的gem,并解决可能出现的编码和兼容性问题。通过参考提供的博客和PDF文档,你可以获取到更全面的指南和解决方案。
rails连接oracle需要的驱动 执行命令:C:\> ruby 文件名.rb <br>
在Rails中,我们通常通过`Gemfile`来指定SQLite gem(如`sqlite3-ruby`或`sqlite3`),然后在`bundle install`时,这个DLL会被添加到系统的PATH中,使得Rails应用能够调用其功能。 在Rails 2.0中,配置SQLite数据库...
### JavaEye2.0_on_rails:敏捷Web开发实践与Ruby on Rails的应用 #### 敏捷软件开发方法 - **背景**:传统软件工程方法在实际应用中面临着项目延期、成本超支以及软件质量不高的问题。为了克服这些挑战,业界提出...
学习Ruby on Rails 4.0的逐步指南。 它包括针对Ruby 2.0.0的基本教程,是为至少了解另一种编程语言并熟悉HTML的程序员编写的。
总结上述知识点,在构建高可用的rails应用时,需要综合考虑多个组件的配置,以及对性能的持续监控与优化。整个架构需要确保在单点故障情况下应用的持续可用,同时还要有良好的扩展性和维护性。对于有一定Ruby基础的...
在开发基于Web的应用程序时,Ruby on Rails(简称Rails)框架和MySQL数据库的结合是常见的选择。本文将详细介绍如何在Windows环境下配置Ruby on Rails以支持Rails 2.3.5及以上版本,并与MySQL进行无缝对接。 首先,...
通过学习这篇教程,开发者不仅可以掌握如何在Rails环境中配置Oracle,还能了解到如何解决可能出现的兼容性问题和优化性能。 【知识点】: 1. **Oracle 数据库介绍**:Oracle数据库以其高性能、高可用性和安全性在...
标题 "rails3.1安装与mysql配置 windows" 涉及到的是在Windows操作系统上安装Ruby on Rails 3.1框架并配置MySQL数据库的过程。这是一个关键的开发环境设置步骤,对于使用Rails进行Web开发的程序员来说至关重要。Ruby...