TutorialsArena

PostgreSQL Version History: A Comprehensive Overview of Key Releases

Explore the evolution of PostgreSQL with this comprehensive overview of its release history. This article summarizes key features, improvements, and significant changes introduced in each major and minor version. #PostgreSQL #VersionHistory #ReleaseNotes #Database #OpenSource #PostgreSQLVersions



PostgreSQL Versions: A Release History

Introduction

PostgreSQL, a powerful open-source relational database, has a rich history of releases. This article provides a summary of significant PostgreSQL versions, highlighting key features and improvements introduced in each release.

PostgreSQL Versioning

PostgreSQL versions are identified by major and minor release numbers. Major releases often involve significant changes or additions, while minor releases typically focus on bug fixes, performance improvements, and security updates. Major versions are generally supported for five years, with one final minor release after that marking the "end-of-life" (EOL).

Release History Summary

Here's a summary of key PostgreSQL releases. Note that this is not an exhaustive list of every minor release; only notable versions are included.

Release Release Date Key Features/Improvements
PostgreSQL 9.5 May 1, 1995 Initial release; versions 0.01, 0.02, 0.03
PostgreSQL 9.5 (0.02) May 25, 1995 CREATE DATABASE syntax change, new tools (pgperl, pg_dump), bug fixes.
PostgreSQL 9.5 (0.03) July 21, 1995 Handling of databases from previous versions, syntax changes (GRANT/REVOKE instead of CHANGE ACL), quoting changes, bug fixes.
PostgreSQL 1.0 September 5, 1995 Improvements to COPY command, addition of SQL LIKE syntax, new port (IRIX 5.3), bug fixes.
PostgreSQL 1.01 February 23, 1996 Improved documentation, added CAST AS syntax, performance enhancements to pg_dump, bug fixes.
PostgreSQL 1.02 August 1, 1996 Enhancements to date/time functions, psql improvements, bug fixes.
PostgreSQL 6.0 January 29, 1997 Added UNIQUE indexes, libpq++ improvements, COPY command improvements, access control enhancements, BETWEEN and IN qualifiers, psql enhancements, bug fixes.
PostgreSQL 6.1 July 22, 1997 pg_dumpall and pg_dump ownership reservation, new psql connection option, timestamp fixes, username changes, bug fixes.
PostgreSQL 6.2 October 17, 1997 Multiline strings, improved DEFAULT handling, enhanced Boolean handling, trigger function improvements, improved output of now() and current, new allowed column names, bug fixes.
PostgreSQL 6.3 March 1, 1998 Client-side environment variable support, default privileges changes, SQL92 subselect support, hash function additions, system index renaming, SQL92 PRIMARY KEY and UNIQUE support, deadlock detection improvements, pg_dump option changes, character limit increases, bug fixes.
PostgreSQL 6.4 October 30, 1998 Added SQL92-compatible syntax, client-server communication improvements, improved installation system, view and rule functionality, psql enhancements, EXPLAIN improvements, configuration options, version() function, JDBC improvements, libpq enhancements, GROUP BY enhancements, bug fixes.
PostgreSQL 6.5 June 9, 1999 Added exact numeric data type, CASE, INTERSECT, and EXCEPT statement support, interface improvements, new platform support, performance improvements, expression additions, ODBC driver updates, multiple rule actions, improved statistics, bug fixes.
PostgreSQL 7.0 May 8, 2000 (Further details on PostgreSQL 7.0 and subsequent versions would be added here, following the same format as above.)

PostgreSQL Versions: A History of Enhancements

Introduction

PostgreSQL, a powerful open-source database, has seen continuous development and improvement over the years. This page provides a historical overview of key PostgreSQL releases, highlighting major features and enhancements.

Understanding PostgreSQL Versioning

PostgreSQL uses a versioning scheme with major and minor release numbers. Major releases often introduce significant changes and new features. Minor releases focus primarily on bug fixes, performance improvements, and security updates. The PostgreSQL Global Development Group typically provides five years of support for each major release, followed by one final minor release containing fixes.

Key PostgreSQL Versions and Their Enhancements

Below is a summary of important PostgreSQL releases, focusing on major version updates and their key improvements. Note that this is not an exhaustive list of every single minor release within each major version.

Version Release Date Key Features and Enhancements
PostgreSQL 7.0 May 8, 2000 psql updates, SQL92 JOIN syntax, ODBC and JDBC improvements, removal of `:` and `;` operators, TRUNCATE command, CREATE FUNCTION enhancements, SET FSYNC command, pg_description support.
PostgreSQL 7.1 April 13, 2001 SQL92 outer join support, subqueries in FROM clause, cluster improvements, enhanced error messages, improved dependency ordering in pg_dump, functional indexes, pg_config utility.
PostgreSQL 7.2 February 4, 2002 MD5 password encryption, multilingual messages, safe transaction ID wraparound, unique indexes on system tables, millisecond transaction timing, temporary file directory specification.
PostgreSQL 7.3 November 27, 2002 ALTER TABLE ... DROP COLUMN functionality, query performance improvements, enhanced logging, multibyte and locale support, object dependency tracking, improved hash functions, SSL enhancements, default_statistics_target configuration variable, increased identifier length, date/time improvements.
PostgreSQL 7.4 November 17, 2003 Improved GROUP BY processing, explicit JOIN syntax, function inlining, improved IN and NOT IN subqueries, multikey hash join, enhanced regular expressions, SSL improvements, free space map enhancements, new client-server protocol, full-text indexing improvements, array handling improvements, autovacuum improvements, thread-safe libpq and ECPG.
PostgreSQL 8.0 January 19, 2005 Windows server support, runs as a Windows service, support for various Windows versions, ALTER TABLE data type changes, COPY command improvements for CSV files, checkpoint, buffer management, and vacuum enhancements, cross-data-type index usage, nested transactions, CREATE SCHEMA enhancements.
PostgreSQL 8.1 November 8, 2005 Two-phase commit support, improved concurrent access to shared buffer cache, automatic index usage for MAX() and MIN(), added dependencies for shared objects, partitioned table performance improvements, index scan enhancements.
PostgreSQL 8.2 December 5, 2006 Non-blocking index creation, improved vacuuming, INSERT, UPDATE, and DELETE improvements, enhanced sorting performance, array and null handling enhancements, table inheritance improvements.
PostgreSQL 8.3 February 4, 2008 User-defined type modifiers, full-text search integration, ENUM type support, updatable cursors, SQL/XML support.

PostgreSQL Release History

The table below summarizes key PostgreSQL releases, highlighting significant additions and changes. Note that this isn't an exhaustive list of every minor release within each major version; only major updates and noteworthy features are included.

Version Release Date Key Improvements and New Features
PostgreSQL 7.0 May 8, 2000 psql updates, SQL92 JOIN syntax, improved ODBC and JDBC, removal of `:` and `;` operators, TRUNCATE command, CREATE FUNCTION enhancements, SET FSYNC command, pg_description support.
PostgreSQL 7.1 April 13, 2001 SQL92 outer join support, subqueries in FROM clause, various improvements (cluster, function creation, file descriptor cache, pg_dump), functional indexes, pg_config utility.
PostgreSQL 7.2 February 4, 2002 MD5 password encryption, multilingual messages, transaction ID wraparound safety, unique indexes on system tables, millisecond transaction timing, dedicated temporary file directory.
PostgreSQL 7.3 November 27, 2002 ALTER TABLE ... DROP COLUMN, query performance enhancements, improved logging, multibyte and locale support, object dependency tracking, enhanced hash functions, SSL improvements, default_statistics_target, increased identifier length, date/time improvements.
PostgreSQL 7.4 November 17, 2003 Enhanced GROUP BY using hash buckets, explicit JOIN syntax, function inlining, improved IN and NOT IN subqueries, multikey hash join, faster regular expressions, SSL improvements, free space map improvements, new client-server protocol, full-text indexing improvements, improved array handling, autovacuum enhancements, thread-safe libpq and ECPG.
PostgreSQL 8.0 January 19, 2005 Windows server support (runs as a service), ALTER TABLE data type changes, COPY command CSV support, improved checkpoint, buffer management, and vacuum, cross-data-type index usage, nested transactions (savepoints), CREATE SCHEMA enhancements for triggers, indexes, and sequences.
PostgreSQL 8.1 November 8, 2005 Two-phase commit, improved concurrent buffer cache access, automatic index usage for MAX() and MIN(), role dependencies on shared objects, partitioned table performance improvements, index scan enhancements.
PostgreSQL 8.2 December 5, 2006 Non-blocking index creation, improved vacuuming, INSERT, UPDATE, DELETE improvements, faster sorting, array and NULL handling improvements, table inheritance.
PostgreSQL 8.3 February 4, 2008 User-defined type modifiers, full-text search integration, ENUM types, updatable cursors, SQL/XML support.
PostgreSQL 8.4 July 1, 2009 psql editing, column permissions, common table expressions (CTEs) and recursive queries, hash index improvements, database locale settings, SSL certificate support for authentication, improved JOIN performance for EXISTS and NOT EXISTS queries.
PostgreSQL 9.0 September 20, 2010 New trigger features, 64-bit Windows support, improved VACUUM FULL, RADIUS and LDAP authentication, granular object permissions, improved stored procedures.
PostgreSQL 9.1 September 12, 2011 Streaming replication, synchronous replication, serializable isolation level, foreign tables, unlogged tables, SECURITY LABEL command, PL/Python updates, per-column collation, extensions.
PostgreSQL 9.2 September 10, 2012 Range types, index-only scans, JSON data type, improved nested loop joins, pg_receivexlog, custom query plans for prepared statements, SP-GiST index, security barrier for views.
PostgreSQL 9.3 September 9, 2013 Non-blocking foreign key updates, event triggers, enhanced JSON functions and operators, PostgreSQL foreign-data wrapper, materialized views, LATERAL joins.
PostgreSQL 9.4 December 18, 2014 Logical decoding, reduced locking for ALTER TABLE, ALTER SYSTEM command, improved jsonb, materialized views.
PostgreSQL 9.5 January 7, 2016 BRIN indexes, enhanced GROUP BY (cube, grouping sets, rollup), improved INSERT conflict handling, multi-CPU performance improvements, replication improvements, row-level security, improved sorting performance.
PostgreSQL 9.6 September 29, 2016 Synchronous replication for multiple standby servers, full-text search phrase support, improved vacuuming, multi-CPU scalability enhancements, parallel query execution, postgres_fdw enhancements.
PostgreSQL 10 October 5, 2017 Improved password authentication (SCRAM-SHA-256), parallel CREATE INDEX, JSONB improvements, pg_stat_statements enhancements, improved partitioning, and more.
PostgreSQL 11 October 3, 2018 Parallel query capabilities, improved indexing, enhanced PARTITIONING, and more.
PostgreSQL 12 October 3, 2019 Improvements in performance, security, and features.
PostgreSQL 13 September 10, 2020 Enhanced performance and new features.
PostgreSQL 14 November 17, 2021 Further performance improvements and feature additions.
PostgreSQL 15 October 19, 2022 Performance improvements and new features.

PostgreSQL 10 (October 5, 2017)

PostgreSQL 10 brought significant enhancements, focusing on:

  • Improved Password Authentication: Stronger password security using SCRAM-SHA-256.
  • Parallel CREATE INDEX: Faster index creation using multiple cores.
  • JSONB Enhancements: Improvements to the JSONB data type for better performance and functionality.
  • pg_stat_statements Enhancements: Better query monitoring tools.
  • Improved Partitioning: Enhanced performance for partitioned tables.

PostgreSQL 11 (October 18, 2018)

PostgreSQL 11 focused on scalability and performance. Key improvements included:

  • INCLUDE Clause for Indexes: Allows including non-key columns in indexes.
  • Embedded Transactions in Stored Procedures: Enhanced support for stored procedure transactions.
  • Improved Partitioning: Further enhancements to partitioning, including support for UPDATE statements that modify partition keys.
  • Optimized SELECT Performance: Improved partition elimination strategies for faster queries.
  • Enhanced Query Parallelism: Improved parallel query execution capabilities.
  • Improved Monitoring and Control: Enhanced tools for database monitoring and management.
  • Logical Replication Enhancements: Improvements to the publishing and subscription capabilities.
  • Declarative Table Partitioning: Easier to manage and define partitioned tables.

PostgreSQL 12 (October 3, 2019)

PostgreSQL 12 focused on performance and added new features:

  • Generated Columns: Ability to define columns whose values are automatically computed.
  • LDAP Authentication Enhancements: Improved LDAP server discovery and authentication.
  • GSSAPI Authentication with Encryption: Enhanced security for network connections.
  • Administrative Enhancements: Improvements to various administrative tools and features.
  • B-Tree Index Performance: Optimized space usage, read/write performance.
  • GiST Index Improvements: Support for covering indexes using the INCLUDE clause.

Conclusion

PostgreSQL's recent releases have focused on performance enhancements and extending functionality. These improvements benefit users through better scalability, easier data management, and improved security.