PostgreSQL driver and toolkit for Go
 
 
 
Go to file
Jack Christensen c672c0d595 Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
chunkreader Reduce allocations and copies in pgproto3 2017-04-29 11:55:14 -05:00
examples Fix go vet issues 2018-01-13 10:08:02 -06:00
internal/sanitize Use github.com/pkg/errors 2017-06-04 21:30:03 -05:00
log Small typo 2018-03-21 00:25:14 -04:00
pgconn Move connection tests to pgconn 2018-12-30 21:10:06 -06:00
pgio Remove read functions from pgio and update docs 2017-05-06 08:54:47 -05:00
pgmock Type modifier should be int32 not uint32 2018-09-22 07:43:18 -05:00
pgpassfile Restructure connect process 2018-12-30 16:55:56 -06:00
pgproto3 Type modifier should be int32 not uint32 2018-09-22 07:43:18 -05:00
pgtype Apply UUID string length check before parsing 2018-11-30 15:13:43 +05:00
stdlib Added LastStmtSent and use it to retry on errors if statement was not sent 2018-11-19 10:44:40 -05:00
travis Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
.gitignore Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
.travis.yml Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
CHANGELOG.md Update changelog for v3.3.0 2018-12-01 11:13:13 -06:00
LICENSE Add license 2013-07-30 19:05:09 -05:00
README.md Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
batch.go Rename base.Conn to base.PgConn 2018-12-28 12:16:50 -06:00
batch_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
bench-tmp_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
bench_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
conn.go Restructure connect process 2018-12-30 16:55:56 -06:00
conn_pool.go Restructure connect process 2018-12-30 16:55:56 -06:00
conn_pool_private_test.go Make ConnPool.Acquire() non blocking, feedback 2016-07-06 16:22:59 +03:00
conn_pool_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
conn_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
copy_from.go Rename base.Conn to base.PgConn 2018-12-28 12:16:50 -06:00
copy_from_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
copy_to.go Adds RowsAffected for CopyToWriter and CopyFromReader 2018-12-13 12:54:42 +03:00
copy_to_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
doc.go tls: stop sending ssl_renegotiation_limit in startup message 2018-10-29 21:50:09 -07:00
example_custom_type_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
example_json_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
fastpath.go Rename base.Conn to base.PgConn 2018-12-28 12:16:50 -06:00
go_stdlib.go Support nil pointers to value implementing driver.Valuer 2017-10-26 21:37:06 -04:00
helper_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
large_objects.go Use Go casing convention for OID 2017-06-03 11:53:49 -05:00
large_objects_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
logger.go Use github.com/pkg/errors 2017-06-04 21:30:03 -05:00
messages.go Rename base package to pgconn 2018-12-28 17:09:56 -06:00
private_test.go Rename base.Conn to base.PgConn 2018-12-28 12:16:50 -06:00
query.go Rename runtime params to parameter status 2018-12-28 12:25:59 -06:00
query_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
replication.go Restructure connect process 2018-12-30 16:55:56 -06:00
replication_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
sql.go Cleanups 2016-08-30 20:05:44 +02:00
sql_test.go Cleanups 2016-08-30 20:05:44 +02:00
stress_test.go Call context.WithTimeout cancel function 2018-09-15 13:23:09 +03:00
tx.go Rename base.Conn to base.PgConn 2018-12-28 12:16:50 -06:00
tx_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
v4.md Use environment variables for test configuration 2018-12-30 21:52:33 -06:00
values.go Convert driver.Valuer's earlier in bind path 2018-09-01 21:37:16 -05:00
values_test.go Use environment variables for test configuration 2018-12-30 21:52:33 -06:00

README.md

Build Status

pgx - PostgreSQL Driver and Toolkit

pgx is a pure Go driver and toolkit for PostgreSQL. pgx is different from other drivers such as pq because, while it can operate as a database/sql compatible driver, pgx is also usable directly. It offers a native interface similar to database/sql that offers better performance and more features.

var name string
var weight int64
err := conn.QueryRow("select name, weight from widgets where id=$1", 42).Scan(&name, &weight)
if err != nil {
    return err
}

Features

pgx supports many additional features beyond what is available through database/sql.

  • Support for approximately 60 different PostgreSQL types
  • Batch queries
  • Single-round trip query mode
  • Full TLS connection control
  • Binary format support for custom types (can be much faster)
  • Copy protocol support for faster bulk data loads
  • Extendable logging support including built-in support for log15 and logrus
  • Connection pool with after connect hook to do arbitrary connection setup
  • Listen / notify
  • PostgreSQL array to Go slice mapping for integers, floats, and strings
  • Hstore support
  • JSON and JSONB support
  • Maps inet and cidr PostgreSQL types to net.IPNet and net.IP
  • Large object support
  • NULL mapping to Null* struct or pointer to pointer.
  • Supports database/sql.Scanner and database/sql/driver.Valuer interfaces for custom types
  • Logical replication connections, including receiving WAL and sending standby status updates
  • Notice response handling (this is different than listen / notify)

Performance

pgx performs roughly equivalent to go-pg and is almost always faster than pq. When parsing large result sets the percentage difference can be significant (16483 queries/sec for pgx vs. 10106 queries/sec for pq -- 63% faster).

In many use cases a significant cause of latency is network round trips between the application and the server. pgx supports query batching to bundle multiple queries into a single round trip. Even in the case of a connection with the lowest possible latency, a local Unix domain socket, batching as few as three queries together can yield an improvement of 57%. With a typical network connection the results can be even more substantial.

See this gist for the underlying benchmark results or checkout go_db_bench to run tests for yourself.

In addition to the native driver, pgx also includes a number of packages that provide additional functionality.

github.com/jackc/pgx/stdlib

database/sql compatibility layer for pgx. pgx can be used as a normal database/sql driver, but at any time the native interface may be acquired for more performance or PostgreSQL specific functionality.

github.com/jackc/pgx/pgtype

Approximately 60 PostgreSQL types are supported including uuid, hstore, json, bytea, numeric, interval, inet, and arrays. These types support database/sql interfaces and are usable even outside of pgx. They are fully tested in pgx and pq. They also support a higher performance interface when used with the pgx driver.

github.com/jackc/pgx/pgproto3

pgproto3 provides standalone encoding and decoding of the PostgreSQL v3 wire protocol. This is useful for implementing very low level PostgreSQL tooling.

github.com/jackc/pgx/pgmock

pgmock offers the ability to create a server that mocks the PostgreSQL wire protocol. This is used internally to test pgx by purposely inducing unusual errors. pgproto3 and pgmock together provide most of the foundational tooling required to implement a PostgreSQL proxy or MitM (such as for a custom connection pooler).

Documentation

pgx includes extensive documentation in the godoc format. It is viewable online at godoc.org.

Testing

pgx supports multiple connection and authentication types. Setting up a test environment that can test all of them can be cumbersome. In particular, Windows cannot test Unix domain socket connections. Because of this pgx will skip tests for connection types that are not configured.

pgx uses environment variables to configure the test database connections. Consider using direnv to simplify this.

Normal Test Environment

To setup the normal test environment, first install these dependencies:

go get github.com/cockroachdb/apd
go get github.com/hashicorp/go-version
go get github.com/jackc/fake
go get github.com/lib/pq
go get github.com/pkg/errors
go get github.com/satori/go.uuid
go get github.com/shopspring/decimal
go get github.com/sirupsen/logrus
go get go.uber.org/zap
go get gopkg.in/inconshreveable/log15.v2

Then run the following SQL:

create user pgx_md5 password 'secret';
create user " tricky, ' } "" \ test user " password 'secret';
create database pgx_test;
create user pgx_replication with replication password 'secret';

Connect to database pgx_test and run:

create extension hstore;
create domain uint64 as numeric(20,0);

Run the tests with environment variable PGX_TEST_DATABASE set to your test database.

PGX_TEXT_DATABASE="host=/var/run/postgresql database=pgx_test" go test ./...

Connection and Authentication Test Environment

Additional tests are available for specific connection types (e.g. TCP, Unix domain sockets, no password, plain password, MD5 password, etc).

Complete the normal test environment setup and also do the following.

Run the following SQL:

create user pgx_none;
create user pgx_pw password 'secret';

Add the following to your pg_hba.conf:

If you are developing on Unix with domain socket connections:

local  pgx_test  pgx_none  trust
local  pgx_test  pgx_pw    password
local  pgx_test  pgx_md5   md5

If you are developing on Windows with TCP connections:

host  pgx_test  pgx_none  127.0.0.1/32 trust
host  pgx_test  pgx_pw    127.0.0.1/32 password
host  pgx_test  pgx_md5   127.0.0.1/32 md5

Each different test connection type uses a different connection string in an environment variable.

export PGX_TEST_UNIX_SOCKET_CONN_STRING="host=/var/run/postgresql database=pgx_test"
export PGX_TEST_TCP_CONN_STRING="host=127.0.0.1 user=pgx_md5 password=secret database=pgx_test"
export PGX_TEST_TLS_CONN_STRING="host=127.0.0.1 user=pgx_md5 password=secret database=pgx_test sslmode=require"
export PGX_TEST_MD5_PASSWORD_CONN_STRING="host=127.0.0.1 user=pgx_md5 password=secret database=pgx_test"
export PGX_TEST_PLAIN_PASSWORD_CONN_STRING="host=127.0.0.1 user=pgx_pw password=secret database=pgx_test"

Replication Test Environment

Add a replication user:

create user pgx_replication with replication password 'secret';

Add a replication line to your pg_hba.conf:

host replication pgx_replication 127.0.0.1/32 md5

Change the following settings in your postgresql.conf:

wal_level=logical
max_wal_senders=5
max_replication_slots=5

Set the replication environment variable.

export PGX_TEST_REPLICATION_CONN_STRING="host=127.0.0.1 user=pgx_replication password=secret database=pgx_test"

Version Policy

pgx follows semantic versioning for the documented public API on stable releases. Branch v3 is the latest stable release. master can contain new features or behavior that will change or be removed before being merged to the stable v3 branch (in practice, this occurs very rarely). v2 is the previous stable release.