質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

1回答

5512閲覧

Windows上で Ruby On Rails から Postgresql 使用で pg_ext (LoadError)と表示される

Chikaemon

総合スコア11

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

1クリップ

投稿2016/06/07 05:28

Windows環境でRuby on railsの勉強を始めた者です。
環境は
・Windows 7 32Bit
・Ruby 2.3.0p0 (2015-12-25 revision 53290) [i386-mingw32]
・Rails 4.2.6
・PostgreSQL 9.5.1

ここで

rails new mypage --database=postgresql

として新規プロジェクトを作成し、

rails s

で起動したところ、以下のエラーとなり起動できません。

E:\RubyWork\asagao>rails s E:/Ruby23/lib/ruby/gems/2.3.0/gems/pg-0.18.4-x86-mingw32/lib/pg.rb:14:in `requir e': cannot load such file -- 2.3/pg_ext (LoadError) from E:/Ruby23/lib/ruby/gems/2.3.0/gems/pg-0.18.4-x86-mingw32/lib/pg.rb: 14:in `rescue in <top (required)>' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/pg-0.18.4-x86-mingw32/lib/pg.rb: 3:in `<top (required)>' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/bundler-1.12.5/lib/bundler/runti me.rb:86:in `require' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/bundler-1.12.5/lib/bundler/runti me.rb:86:in `block (2 levels) in require' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/bundler-1.12.5/lib/bundler/runti me.rb:81:in `each' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/bundler-1.12.5/lib/bundler/runti me.rb:81:in `block in require' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/bundler-1.12.5/lib/bundler/runti me.rb:70:in `each' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/bundler-1.12.5/lib/bundler/runti me.rb:70:in `require' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/bundler-1.12.5/lib/bundler.rb:10 2:in `require' from E:/RubyWork/asagao/config/application.rb:7:in `<top (required)>' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/railties-4.2.6/lib/rails/command s/commands_tasks.rb:78:in `require' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/railties-4.2.6/lib/rails/command s/commands_tasks.rb:78:in `block in server' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/railties-4.2.6/lib/rails/command s/commands_tasks.rb:75:in `tap' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/railties-4.2.6/lib/rails/command s/commands_tasks.rb:75:in `server' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/railties-4.2.6/lib/rails/command s/commands_tasks.rb:39:in `run_command!' from E:/Ruby23/lib/ruby/gems/2.3.0/gems/railties-4.2.6/lib/rails/command s.rb:17:in `<top (required)>' from bin/rails:4:in `require' from bin/rails:4:in `<main>'

pg_ext は
\Ruby\lib\ruby\gems\2.3.0\gems\pg-0.18.4-x86-mingw32\lib\x.x\pg_ext.so を指していると思いますが
バージョン毎のフォルダ(上記パスのx.x部)は、

E:\RUBY23\LIB\RUBY\GEMS\2.3.0\GEMS\PG-0.18.4-X86-MINGW32\LIB ├─1.9 pg_ext.so ├─2.0 pg_ext.so ├─2.1 pg_ext.so ├─2.2 pg_ext.so ├─i386-mingw32 libpq.dll Ver-9.4.4.15317 └─pg

となっています。
何が足りないのかご教授願います。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Windows向けのpg Gemには、あらかじめWindowsのRuby向けにコンパイルされたバイナリのランタイムが付属していますが、これがRuby 2.2用までしかないので、Ruby 2.3ではエラーとなってしまします。

自力でコンパイルするには、PostgreSQLの開発用ヘッダーをインストール、またはそれを入れたDocker上でコンパイルするなど面倒な手順が必要となります(Gem添付のREADME-Windows.rdocを御覧ください)。

そこまでするだけの技量がないなら、Ruby 2.2に戻すのが手っ取り早いです。

投稿2016/06/09 02:12

maisumakun

総合スコア145123

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Chikaemon

2016/06/11 02:05

回答ありがとうございます。 Ruby 2.2をインストールし、動作が確認できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問