Download
Binary JAR file downloads of the JDBC driver are available here and the current version with Maven Repository. Because Java is platform neutral, it is a simple process of just downloading the appropriate JAR file and dropping it into your classpath. Source versions are also available here for recent driver versions. Latest SNAPSHOT versions.
Latest Versions
This is the current version of the driver. Unless you have unusual requirements (running old applications or JVMs), this is the driver you should be using. It supports PostgreSQL 8.2 or newer and requires Java 6 or newer. It contains support for SSL and the javax.sql package.
If you are using Java 8 or newer then you should use the JDBC 4.2 version.
If you are using Java 7 then you should use the JDBC 4.1 version.
If you are using Java 6 then you should use the JDBC 4.0 version.
Older Versions
Many other versions of the JDBC driver are available. This includes development versions, compatibility with older JDKs, and previous versions of the driver.
- Getting Started
- Initializing the Driver
- Using SSL
- Issuing a Query and Processing the Result
- Calling Stored Functions and Procedures
- Storing Binary Data
- JDBC escapes
- PostgreSQL™ Extensions to the JDBC API
- Using the Driver in a Multithreaded or a Servlet Environment
- Connection Pools and Data Sources
- Logging using java.util.logging
- Further Reading
Setting up the JDBC Driver
This section describes the steps you need to take before you can write or run programs that use the JDBC interface.
Getting the Driver
Precompiled versions of the driver can be downloaded from the PostgreSQL® JDBC web site.
Alternatively you can build the driver from source, but you should only need to do this if you are making changes to the source code. To build the JDBC driver, you need gradle and a JDK (currently at least jdk1.8).
If you have several Java compilers installed, maven will use the first one on the path. To use a different one set JAVA_HOME to the Java version you wish to use. For example, to use a different JDK than the default, this may work:
JAVA_HOME=/usr/local/jdk1.8.0_45
To compile the driver simply run gradlew assemble or gradlew build if you want to run the tests in the top level directory.
NOTE
If you want to skip test execution, add the option -DskipTests . The compiled driver will be placed in pgjdbc/build/libs/postgresql-MM.nn.pp.jar
Where MM is the major version, nn is the minor version and pp is the patch version. Versions for JDBC3 and lower can be found here
This is a very brief outline of how to build the driver. Much more detailed information can be found on the github repo
Even though the JDBC driver should be built with Gradle, for situations, where use of Gradle is not possible, e.g., when building pgJDBC for distributions, the pgJDBC Gradle build provides a convenience source release artifact *-src.tar.gz — a Maven based project. The Maven based project contains a version of the JDBC driver with complete functionality, which can be used in production and is still validly buildable within the Maven build environment. The Maven-based project is created with gradlew -d :postgresql:sourceDistribution -Prelease . The produced *-src.tar.gz can be then found in pgjdbc/build/distributions/ directory. JDBC driver can be built from the Maven-based project with mvn package or, when the tests are to be skipped, with mvn -DskipTests package . Source files *-src.tar.gz ’s are released in the Maven central repository.
Setting up the Class Path
To use the driver, the JAR archive named postgresql-MM.nn.pp.jar needs to be included in the class path, either by putting it in the CLASSPATH environment variable, or by using flags on the java command line.
For instance, assume we have an application that uses the JDBC driver to access a database, and that application is installed as /usr/local/lib/myapp.jar . The PostgreSQL® JDBC driver installed as /usr/local/pgsql/share/java/postgresql-MM.nn.pp.jar . To run the application, we would use:
export CLASSPATH=/usr/local/lib/myapp.jar:/usr/local/pgsql/share/java/postgresql-42.5.0.jar:. java MyApp
Current Java applications will likely use maven, gradle or some other package manager. Use this to search for the latest jars and how to include them in your project
Loading the driver from within the application is covered in Initializing the Driver.
Preparing the Database Server for JDBC
Out of the box, Java does not support unix sockets so the PostgreSQL® server must be configured to allow TCP/IP connections. Starting with server version 8.0 TCP/IP connections are allowed from localhost . To allow connections to other interfaces than the loopback interface, you must modify the postgresql.conf file’s listen_addresses setting.
Once you have made sure the server is correctly listening for TCP/IP connections the next step is to verify that users are allowed to connect to the server. Client authentication is setup in pg_hba.conf . Refer to the main PostgreSQL® documentation for details .
Creating a Database
When creating a database to be accessed via JDBC it is important to select an appropriate encoding for your data. Many other client interfaces do not care what data you send back and forth, and will allow you to do inappropriate things, but Java makes sure that your data is correctly encoded. Do not use a database that uses the SQL_ASCII encoding. This is not a real encoding and you will have problems the moment you store data in it that does not fit in the seven bit ASCII character set. If you do not know what your encoding will be or are otherwise unsure about what you will be storing the UNICODE encoding is a reasonable default to use.
PostgreSQL JDBC Driver
The PostgreSQL JDBC Driver allows Java programs to connect to a PostgreSQL database using standard, database independent Java code. pgJDBC is an open source JDBC driver written in Pure Java (Type 4), and communicates in the PostgreSQL native network protocol. Because of this, the driver is platform independent; once compiled, the driver can be used on any system.
Latest Releases
pgJDBC has released v42.6.0 on 17 March, 2023. This release has two major changes: Remove most uses of synchronized in favour of reentrant locks, and remove the use of finalize.
- 42.6.0 · 17 March 2023 · Notes
- 42.5.4 · 16 February 2023 · Notes
- 42.4.3 · 23 October 2022 · Notes
- 42.3.8 · 23 October 2022 · Notes
- 42.2.27 · 23 October 2022 · Notes
pgJDBC allows Java programs to connect to a PostgreSQL database using standard, database independent Java code.
pgJDBC provides a reasonably complete implementation of the JDBC specification in addition to some PostgreSQL specific extensions.
The current development driver supports eleven server versions and three java environments.
Processing a simple query
This example will issue a simple query and print out the first column of each row using a Statement.
Statement st = conn.createStatement(); ResultSet rs = st.executeQuery("SELECT * FROM mytable WHERE columnfoo = 500"); while (rs.next()) System.out.print("Column 1 returned "); System.out.println(rs.getString(1)); > rs.close(); st.close();
Report a bug or Contribute ?
See something that’s wrong or unclear?
submit a PR.
Support Us
PostgreSQL is free.
Please support our work by making a donation.
- Getting Started
- Initializing the Driver
- Using SSL
- Issuing a Query and Processing the Result
- Calling Stored Functions and Procedures
- Storing Binary Data
- JDBC escapes
- PostgreSQL™ Extensions to the JDBC API
- Using the Driver in a Multithreaded or a Servlet Environment
- Connection Pools and Data Sources
- Logging using java.util.logging
- Further Reading