PL/Java may be built on Windows using the compilers in Microsoft Visual Studio (including the Express and Community editions).
Most Windows users will install PostgreSQL using the binary distributions from EnterpriseDB. You may find that using the same version of Visual Studio to compile PL/Java as that used by EnterpriseDB to compile their PostgreSQL distribution will result in fewer compile warnings and a somewhat smaller runtime memory footprint because the same runtime DLLs will be used by both PostgreSQL and PL/Java. Using a newer version of Visual Studio (including the Community 2015 version) will generally work, while older versions are more likely to be problematic.
You will need an appropriate version of Microsoft Visual Studio. When installing Visual Studio be sure to select the “compiler tools” option so that the command line compiler is installed.
The Java Development Kit (not just the Java Runtime Environment) version that you plan to use. that you plan to use should be installed, also ideally in your PATH environment variable so that
javac -version
just works.
The PostgreSQL server version that you intend to use should be installed, and on your PATH so that the command
pg_config
succeeds.
Development files (mostly .h
files) for that PostgreSQL version must also
be installed. To check, look in the output of that pg_config
command for
an INCLUDEDIR-SERVER
line, and list the directory it refers to. There
should be a bunch of *.h
files there.
OpenSSL headers: if using an EnterpriseDB PostgreSQL build older than 9.3,
these will be missing. They can be obtained from a 9.3 or later
EDB PostgreSQL build by copying the include/openssl
directory and
its contents.
You will need to install Maven and add it to your PATH so that
mvn --version
just works.
You will need either Git or GitHub for Windows. If you are using Git, add it to your PATH so that
git --version
just works.
You must match the 32-bit vs 64-bit version of the Java JVM, C compiler and PostgreSQL installation used to build PL/Java. (All must be either 32-bit or 64-bit.)
If you have more than one version installed of PostgreSQL, Java, or the compile/link tools, make sure the ones found on your search path are the ones you plan to use, and the version-test commands above give the output you expect.
You will need to open a command window with the appropriate Visual C native
tools environment variables defined. You may do this by using the preconfigured
links accessible from the Start menu (for example at
Visual Studio 2013 | Visual Studio Tools
) or by creating a desktop shortcut
for the tools.
Visual Studio 2013:
"C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall.bat" x86
"C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall.bat" amd64
Visual Studio 2010:
"C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\vcvarsall.bat" x86
"C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\vcvarsall.bat" amd64
Obtain source for a specific PL/Java release from the
Releases page on GitHub, archived in your choice of zip
or tar.gz
format.
If you have git
, you can also obtain specific-release source by cloning
the repository and checking out the tag that identifies the release.
The best way to obtain up-to-date development PL/Java sources is to clone
the PL/Java GitHub repository, which can be done with GitHub for Windows by
opening your browser to
https://github.com/tada/pljava
and clicking on the appropriate icon. At the time these notes were written, the icon is located to the left of the “Download ZIP” button.
Alternatively you may use git to clone
the PL/Java GitHub repository,
using either of these commands:
git clone https://github.com/tada/pljava.git
git clone ssh://git@github.com/tada/pljava.git
The second only works if you have a GitHub account, but has the advantage
of being faster if you do git pull
later on to stay in sync with updated
sources.
Open a command window using the Visual Studio shortcut for the appropriate version.
To start the build, your current directory should be the one the sources were checked out into. In the command window, change the directory to the location of the cloned PL/Java repository. For example,
cd C:\GitHub\pljava
Looking around, there should be a pom.xml
file there,
and several subdirectories pljava
, pljava-api
, pljava-so
, etc.
PL/Java is built using Apache Maven.
mvn clean install
This command will build PL/Java and produce the files you need, but does not install them as a language in PostgreSQL. To complete that step, proceed to the installation instructions.
A successful mvn clean install
should produce output like this near the end:
[INFO] PostgreSQL PL/Java ................................ SUCCESS
[INFO] PL/Java API ....................................... SUCCESS
[INFO] PL/Java backend Java code ......................... SUCCESS
[INFO] PL/Java backend native code ....................... SUCCESS
[INFO] PL/Java Deploy .................................... SUCCESS
[INFO] PL/Java Ant tasks ................................. SUCCESS
[INFO] PL/Java examples .................................. SUCCESS
[INFO] PL/Java packaging ................................. SUCCESS
(the real output will include timings on each line). You will then be ready to try out PL/Java in PostgreSQL.
If Maven is unfamiliar, please see the “Explain Maven!” section on the main build page, which covers most of the subject. However, there are some Windows-specific details:
The Maven project has an extra page on Windows prerequisites.
They don't very clearly document the location of your Maven settings file when running on Windows. If you want to change any Maven settings, it may be easiest to run
mvn -X
and look for the lines
[DEBUG] Reading global settings from (somewhere)/settings.xml
[DEBUG] Reading user settings from (somewhere)/settings.xml
to find and edit a settings file.
A last reminder, mvn install
does not add PL/Java as a language in your
PostgreSQL database; the Maven install
goal only adds things to your
Maven repository. That isn't even necessary for installing the language in
PostgreSQL, but it will be convenient when you
build your Java projects that use PL/Java.
To “install” your built PL/Java as a language in PostgreSQL, proceed to the installation instructions.
The process of downloading and building PL/Java with Maven will be familiar
to you, but the step saving artifacts into the local repository with the
install
goal is only a first step; PostgreSQL itself
is not Maven-aware and will not find them there. After the mvn clean install
,
just proceed to the installation instructions.
The pljava-api
subproject does benefit from being saved in your local
Maven repository; you can then declare it like any other Maven
dependency when building your own projects that use PL/Java.
If something fails, two tricks may be helpful. The C compilation may produce a lot of nuisance warnings, because the Maven plugin driving it enables many types of warning that would be impractical to fix. With many warnings it may be difficult to pick out messages that matter.
If the link step of the build reports that the symbol rint
is undefined you
are probably using an older version of Visual Studio (2010) with a newer version
of Postgresql (9.4). This symbol is defined in Visual Studio 2013 and later and
the Postgresql 9.4 headers lack the appropriate conditional options for the
older compilers. You will need to use a newer version of Visual Studio.
On a machine with many cores, messages from several compilation threads may be
intermingled in the output so that related messages are hard to identify.
The option -Dnar.cores=1
will force the messages into a sequential order
(and has little effect on the speed of a PL/Java build).
The -X
option will add a lot of information on the details of Maven's
build activities.
mvn -X -Dnar.cores=1 clean install
There is a more comprehensive “troubleshooting the build” section on the main build page.