(以下は PostgreSQL を例にしてますが、他のドライバでも通用すると思います)
install
まずは JRuby 用のドライバをインストールします。
shell>>
% gem install activerecord-jdbcpostgresql-adapter
<<--
設定
通常は database.yml に "adapter: jdbcpostgresql" と記述して利用するのですが、ここでは別の方法を紹介します。
内容は簡単で以下のコードを評価するだけです。
ruby>>
if RUBY_PLATFORM == "java"
require "active_record/connection_adapters/jdbcpostgresql_adapter"
end
<<--
(Railsであれば "config/initializers/jruby_compat.rb" などに記述しておくとよいでしょう)
メリット
- MRI と同じアダプタ名 "postgresql" を利用できる
- 変更なしで MRI, JRuby のどちらでも動作する
実行例
shell>>
% rvm use system
% ./script/console
User.count
=> 6User.connection.class
=> ActiveRecord::ConnectionAdapters::PostgreSQLAdapter
% rvm use jruby
% ./script/console
User.count
=> 6User.connection.class
=> ActiveRecord::ConnectionAdapters::JdbcAdapter
<<--
JRuby はまだ発展途上ですので、
開発や挙動確認で MRI を利用する局面が多々あります。
そんな折、この方法であればいちいち database.yml の内容を変更する必要がないため、非常にシームレス&快適に利用できると思います。