Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings
/pgxPublic

PostgreSQL driver and toolkit for Go

License

NotificationsYou must be signed in to change notification settings

jackc/pgx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Go ReferenceBuild Status

pgx - PostgreSQL Driver and Toolkit

pgx is a pure Go driver and toolkit for PostgreSQL.

The pgx driver is a low-level, high performance interface that exposes PostgreSQL-specific features such asLISTEN /NOTIFY andCOPY. It also includes an adapter for the standarddatabase/sql interface.

The toolkit component is a related set of packages that implement PostgreSQL functionality such as parsing the wire protocoland type mapping between PostgreSQL and Go. These underlying packages can be used to implement alternative drivers,proxies, load balancers, logical replication clients, etc.

Example Usage

package mainimport ("context""fmt""os""github.com/jackc/pgx/v5")funcmain() {// urlExample := "postgres://username:password@localhost:5432/database_name"conn,err:=pgx.Connect(context.Background(),os.Getenv("DATABASE_URL"))iferr!=nil {fmt.Fprintf(os.Stderr,"Unable to connect to database: %v\n",err)os.Exit(1)}deferconn.Close(context.Background())varnamestringvarweightint64err=conn.QueryRow(context.Background(),"select name, weight from widgets where id=$1",42).Scan(&name,&weight)iferr!=nil {fmt.Fprintf(os.Stderr,"QueryRow failed: %v\n",err)os.Exit(1)}fmt.Println(name,weight)}

See thegetting started guide for more information.

Features

  • Support for approximately 70 different PostgreSQL types
  • Automatic statement preparation and caching
  • Batch queries
  • Single-round trip query mode
  • Full TLS connection control
  • Binary format support for custom types (allows for much quicker encoding/decoding)
  • COPY protocol support for faster bulk data loads
  • Tracing and logging support
  • Connection pool with after-connect hook for arbitrary connection setup
  • LISTEN /NOTIFY
  • Conversion of PostgreSQL arrays to Go slice mappings for integers, floats, and strings
  • hstore support
  • json andjsonb support
  • Mapsinet andcidr PostgreSQL types tonetip.Addr andnetip.Prefix
  • Large object support
  • NULL mapping to pointer to pointer
  • Supportsdatabase/sql.Scanner anddatabase/sql/driver.Valuer interfaces for custom types
  • Notice response handling
  • Simulated nested transactions with savepoints

Choosing Between the pgx and database/sql Interfaces

The pgx interface is faster. Many PostgreSQL specific features such asLISTEN /NOTIFY andCOPY are not availablethrough thedatabase/sql interface.

The pgx interface is recommended when:

  1. The application only targets PostgreSQL.
  2. No other libraries that requiredatabase/sql are in use.

It is also possible to use thedatabase/sql interface and convert a connection to the lower-level pgx interface as needed.

Testing

SeeCONTRIBUTING.md for setup instructions.

Architecture

See the presentation at Golang Estonia,PGX Top to Bottom for a description of pgx architecture.

Supported Go and PostgreSQL Versions

pgx supports the same versions of Go and PostgreSQL that are supported by their respective teams. ForGo that is the two most recent major releases and forPostgreSQL the major releases in the last 5 years. This means pgx supports Go 1.24 and higher and PostgreSQL 13 and higher. pgx also is tested against the latest version ofCockroachDB.

Version Policy

pgx follows semantic versioning for the documented public API on stable releases.v5 is the latest stable major version.

PGX Family Libraries

pglogrepl provides functionality to act as a client for PostgreSQL logical replication.

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).

tern is a stand-alone SQL migration system.

pgerrcode contains constants for the PostgreSQL error codes.

Adapters for 3rd Party Types

Adapters for 3rd Party Tracers

Adapters for 3rd Party Loggers

These adapters can be used with the tracelog package.

3rd Party Libraries with PGX Support

pgxmock is a mock library implementing pgx interfaces.pgxmock has one and only purpose - to simulate pgx behavior in tests, without needing a real database connection.

Library for scanning data from a database into Go structs and more.

A carefully designed SQL client for making using SQL easier,more productive, and less error-prone on Golang.

Adds GSSAPI / Kerberos authentication support.

Explicit data mapping and scanning library for Go structs and slices.

Type safe and flexible package for scanning database data into Go types.Supports, structs, maps, slices and custom mapping functions.

Code first migration library for native pgx (no database/sql abstraction).

A database monitoring/metrics library for pgx and sqlc. Trace, log and monitor your sqlc query performance using OpenTelemetry.

Simple Golang implementation for transactional outbox pattern for PostgreSQL using jackc/pgx driver.

Simplifies working with the pgx library, providing convenient scanning of nested structures.

Implementation of the pgx query rewriter to use ':' instead of '@' in named query parameters.

About

PostgreSQL driver and toolkit for Go

Resources

License

Contributing

Stars

Watchers

Forks

Sponsor this project

 

Packages

No packages published

Contributors316

Languages


[8]ページ先頭

©2009-2025 Movatter.jp