Skip to content

Install Postgres gem for windows

Veske edited this page Dec 21, 2014 · 4 revisions

When installing the PostgreSQL database, you probably will need to use the 32bit version of it.

Compiling 'pg' on MS Windows In order to build this extension on MS Windows you will need a couple things.

First, a compiler. For the one click installer this means you should either use VC++ 6.0 or the compiler that comes with cygwin or mingw if you're building on that platform.

If you've built Ruby yourself, you should use the same compiler to build this library that you used to build Ruby.

Second, PostgreSQL. Be sure you installed it with the development header files if you installed it using the standard PostgreSQL installer for Windows. If you didn't, you can run the installer again, select “modify”, and then select the 'development headers' option to install them.

I recommend making sure that 'pg_config.exe' is in your PATH. The PostgreSQL installer for Windows does not necessarily update your PATH when it installs itself, so you may need to do this manually. This isn't strictly necessary, however.

In order to build ruby-pg, just run 'rake'. If the pg_config.exe executable is not in your PATH, you'll need to explicitly point ruby-pg to where your PostgreSQL headers and libraries are with something like this:

rake –with-pg-dir=c:/progra~1/postgr~1/8.3

Adjust your path accordingly. BE SURE TO USE THE SHORT PATH NAMES! If you try to use a path with spaces in it, the nmake.exe program will choke.

Cross compiling for mswin32 Using rake-compiler a cross compiled pg gem can be build on a Linux or MacOS X host for the win32 platform. The generated gem is statically linked against libpq and libssl. OpenSSL and PostgreSQL are downloaded and compiled from the sources. There are no runtime dependencies to any but the standard Windows DLLs.

Install mingw32 using the instructions in rake-compiler's README. For Debian/Ubuntu it is apt-get install gcc-mingw32 . Use ruby-1.8.7 for the following commands.

Download and cross compile ruby 1.8 and 1.9 for win32 with:

rake-compiler cross-ruby VERSION=1.8.7-p352 rake-compiler cross-ruby VERSION=1.9.2-p290

Download and cross compile pg for win32:

rake cross native gem

or with custom versions:

rake cross native gem RUBY_CC_VERSION=1.8.7:1.9.2 \ OPENSSL_VERSION=1.0.0e POSTGRESQL_VERSION=9.1.1

If everything works, there should be pg-VERSION-x86-mingw32.gem in the pkg directory.

Reporting Problems If you have any problems you can submit them via [the project's issue-tracker]. And submit questions, problems, or solutions, so that it can be improved.