A.11. リリース6.5

リリース日: 1999-06-09

このリリースはバークレーから引き継いだソースコードからの、 重要なバージョンアップとなります。お分かり頂けるように、 世界中の、経験のある、すぐれた開発者により、より簡単に大きな機能を 追加できるようになりました。

より注目すべき変更について簡単に要約を示します。

マルチバージョン・コンカレンシー・コントロール(MVCC)

この機能により、今までのテーブルレベルのロックを取り除きました。 また、これにより、ほとんどの商用デー タベースシステムよりも 秀でたものとなりました。伝統的なシステムでは、変更される各行を コミットされるまでロックすることで、他のユーザからの読みとりを防いで いました。書き込み操作中にでも、一貫性をもったデータを読み続けることが できるように、MVCCはPostgreSQLが標準で持つマルチバージョン機能を 使用します。書き込みは簡易なpg_log トランザクションシステムを 使い続けます。これは、伝統的なデータベースシステムで行なわれるような 各行のロック割り当てを全く使用せずに実行されます。したがって、 基本的に単純なテーブルレベルロックによる制限はなく、それに加えて 行レベルのロックよりも優れたものになっています。

pg_dumpを使ったホットバックアップ

pg_dumpと新しいMVCC機能を利用して、 データベースがオンラインで問い合わせに対応できる状態であっても、 一貫性をもつデータベースのダンプ/バックアップができるものです。

数値データ型

ユーザ指定の精度をもった、真の数値データ型を持つようになりました。

一時的テーブル

一時的テーブルはあるデータベースのセッション内で 一意な名前を持つテーブルで、そのセッションの終了時に 削除されるテーブルであることが保証されています。

新しいSQL機能

CASE文、INTERSECT文、EXCEPT文のサポートを行ないました。 新しくLIMIT/OFFSET、SET TRANSACTION ISOLATION LEVEL、 SELECT ... FOR UPDATE文のサポートを行ない、 そして、LOCK TABLEコマンドの改良も行ないました。

速度向上

開発チーム内の多くの人材のおかげで、PostgreSQLの速度向上が続けられています。 メモリ割り当て、最適化、テーブルの結合、行の転送処理についての速度 向上を行ないました。

移植

移植リストの拡張を引き続き行っています。 今回は WinNT/ix86 及び NetBSD/arm32 を追加しました。

インターフェース

ほとんどのインタフェースはバージョンアップされ、 また、既存の機能は改良されました。

ドキュメント

新規文書と更新された文書があります。SGIとAIXプラットフォームに 関するFAQが新しく追加されました。 Stefan Simkovics氏によるSQLの 入門情報がチュートリアル(Tutorial)に書かれています。 ユーザガイド(User's Guide)には、 postmasterとその他多くのユーティリティプログラムが カバーされたリファレンスページや、日付/時刻の動作の詳細を含んだ 付録があります。アドミニストレータガイド (Administrator's Guide)には、Tom Lane氏による 問題解決に関する新しい章があります。そして、 プログラマガイド(Programmer's Guide) には、Stefan氏による問い合わせ処理の説明や、匿名(anonymous)CVSと CVSupによるPostgres のソースコードの入手方法についての詳細情報があります。

A.11.1. 6.5への移行

全てのPostgresの以前のリリースから データを移行する際には、pg_dumpを使用した ダンプ/リストアが必要です。ディスク上のテーブル構成が以前のリリースから 変更されていますので、このリリースへのアップグレードの際に pg_upgradeを使用することは できません

新しいマルチバージョン・コンカレンシー・コントロール(MVCC) 機能は、複数ユーザ環境において異なった動作を引き起こす可能性が あります。既存のアプリケーションが所望の動作を行なうことを 確認するために、下記の節を熟読して下さい。

A.11.1.1. マルチバージョン・コンカレンシー・コントロール

6.5では読み込み時にデータをロックしていなかったので、 トランザクションの隔離レベルにかかわらず、1つのトランザクションで 読み取られたデータは、別のトランザクションによって 上書きされることが可能でした。それはつまり、SELECT文 で返された行は、その返された時(すなわち、問い合わせかトランザクションが 開始された後)には、その行が存在しているということを意味していなく、 また、その行が現在実行されているトランザクションがコミット/ロールバックを 行う前に、同時に実行されている別のトランザクションから削除/更新されるのを 保護していることも意味していません。

実際に存在する行を確実なものとし、かつ、同時更新から保護するためには、 必ずSELECT FOR UPDATE文、または LOCK TABLE文を使用する必要があります。 Postgresの以前のリリース、 または、他の環境からアプリケーションを移植する場合は これを考慮しなければなりません。

contrib/refint.*トリガを参照完全性用に 使用する際には、上記のことを念頭に置いて下さい。 ここでは更に技術が必要となります。1つの方法は、トランザクションが プライマリキーを更新/削除する場合には、 LOCK parent_table IN SHARE ROW EXCLUSIVE MODE コマンドを使用し、トランザクションが外部キーを更新/挿入する場合は LOCK parent_table IN SHARE MODEコマンドを 使用するものです。

Note: SERIALIZABLEモードでトランザクションを実行する際、トランザクションで DML文(SELECT/INSERT/DELETE/UPDATE/FETCH/COPY_TO)を 使用する前に必ずLOCKコマンドを実行する必要がある ことにご注意下さい。

これらの不便な点は将来、隔離レベルに関係なく、コミットされていない ダーティデータの読み込み機能と、正式な参照完全性が実装された時点で 解消されます。

A.11.2. 詳細な変更点一覧

Bug Fixes
---------
Fix text<->float8 and text<->float4 conversion functions(Thomas)
Fix for creating tables with mixed-case constraints(Billy)
Change exp()/pow() behavior to generate error on underflow/overflow(Jan)
Fix bug in pg_dump -z
Memory overrun cleanups(Tatsuo)
Fix for lo_import crash(Tatsuo)
Adjust handling of data type names to suppress double quotes(Thomas)
Use type coercion for matching columns and DEFAULT(Thomas)
Fix deadlock so it only checks once after one second of sleep(Bruce)
Fixes for aggregates and PL/pgsql(Hiroshi)
Fix for subquery crash(Vadim)
Fix for libpq function PQfnumber and case-insensitive names(Bahman Rafatjoo)
Fix for large object write-in-middle, no extra block, memory consumption(Tatsuo)
Fix for pg_dump -d or -D and  quote special characters in INSERT
Repair serious problems with dynahash(Tom)
Fix INET/CIDR portability problems
Fix problem with selectivity error in ALTER TABLE ADD COLUMN(Bruce)
Fix executor so mergejoin of different column types works(Tom)
Fix for Alpha OR selectivity bug
Fix OR index selectivity problem(Bruce)
Fix so \d shows proper length for char()/varchar()(Ryan)
Fix tutorial code(Clark)
Improve destroyuser checking(Oliver)
Fix for Kerberos(Rodney McDuff)
Fix for dropping database while dirty buffers(Bruce)
Fix so sequence nextval() can be case-sensitive(Bruce)
Fix !!= operator
Drop buffers before destroying database files(Bruce)
Fix case where executor evaluates functions twice(Tatsuo)
Allow sequence nextval actions to be case-sensitive(Bruce)
Fix optimizer indexing not working for negative numbers(Bruce)
Fix for memory leak in executor with fjIsNull
Fix for aggregate memory leaks(Erik Riedel)
Allow username containing a dash GRANT permissions
Cleanup of NULL in inet types
Clean up system table bugs(Tom)
Fix problems of PAGER and \? command(Masaaki Sakaida)
Reduce default multi-segment file size limit to 1GB(Peter)
Fix for dumping of CREATE OPERATOR(Tom)
Fix for backward scanning of cursors(Hiroshi Inoue)
Fix for COPY FROM STDIN when using \i(Tom)
Fix for subselect is compared inside an expression(Jan)
Fix handling of error reporting while returning rows(Tom)
Fix problems with reference to array types(Tom,Jan)
Prevent UPDATE SET oid(Jan)
Fix pg_dump so -t option can handle case-sensitive tablenames
Fixes for GROUP BY in special cases(Tom, Jan)
Fix for memory leak in failed queries(Tom)
DEFAULT now supports mixed-case identifiers(Tom)
Fix for multi-segment uses of DROP/RENAME table, indexes(Ole Gjerde)
Disable use of pg_dump with both -o and -d options(Bruce)
Allow pg_dump to properly dump GROUP permissions(Bruce)
Fix GROUP BY in INSERT INTO table SELECT * FROM table2(Jan)
Fix for computations in views(Jan)
Fix for aggregates on array indexes(Tom)
Fix for DEFAULT handles single quotes in value requiring too many quotes
Fix security problem with non-super users importing/exporting large objects(Tom)
Rollback of transaction that creates table cleaned up properly(Tom)
Fix to allow long table and column names to generate proper serial names(Tom)

Enhancements
------------
Add "vacuumdb" utility
Speed up libpq by allocating memory better(Tom)
EXPLAIN all indices used(Tom)
Implement CASE, COALESCE, NULLIF  expression(Thomas)
New pg_dump table output format(Constantin)
Add string min()/max() functions(Thomas)
Extend new type coercion techniques to aggregates(Thomas)
New moddatetime contrib(Terry)
Update to pgaccess 0.96(Constantin)
Add routines for single-byte "char" type(Thomas)
Improved substr() function(Thomas)
Improved multibyte handling(Tatsuo)
Multi-version concurrency control/MVCC(Vadim)
New Serialized mode(Vadim)
Fix for tables over 2gigs(Peter)
New SET TRANSACTION ISOLATION LEVEL(Vadim)
New LOCK TABLE IN ... MODE(Vadim)
Update ODBC driver(Byron)
New NUMERIC data type(Jan)
New SELECT FOR UPDATE(Vadim)
Handle "NaN" and "Infinity" for input values(Jan)
Improved date/year handling(Thomas)
Improved handling of backend connections(Magnus)
New options ELOG_TIMESTAMPS and USE_SYSLOG options for log files(Massimo)
New TCL_ARRAYS option(Massimo)
New INTERSECT and EXCEPT(Stefan)
New pg_index.indisprimary for primary key tracking(D'Arcy)
New pg_dump option to allow dropping of tables before creation(Brook)
Speedup of row output routines(Tom)
New READ COMMITTED isolation level(Vadim)
New TEMP tables/indexes(Bruce)
Prevent sorting if result is already sorted(Jan)
New memory allocation optimization(Jan)
Allow psql to do \p\g(Bruce)
Allow multiple rule actions(Jan)
Added LIMIT/OFFSET functionality(Jan)
Improve optimizer when joining a large number of tables(Bruce)
New intro to SQL from S. Simkovics' Master's Thesis (Stefan, Thomas)
New intro to backend processing from S. Simkovics' Master's Thesis (Stefan)
Improved int8 support(Ryan Bradetich, Thomas, Tom)
New routines to convert between int8 and text/varchar types(Thomas)
New bushy plans, where meta-tables are joined(Bruce)
Enable right-hand queries by default(Bruce)
Allow reliable maximum number of backends to be set at configure time
      (--with-maxbackends and postmaster switch (-N backends))(Tom)
GEQO default now 10 tables because of optimizer speedups(Tom)
Allow NULL=Var for MS-SQL portability(Michael, Bruce)
Modify contrib check_primary_key() so either "automatic" or "dependent"(Anand)
Allow psql \d on a view show query(Ryan)
Speedup for LIKE(Bruce)
Ecpg fixes/features, see src/interfaces/ecpg/ChangeLog file(Michael)
JDBC fixes/features, see src/interfaces/jdbc/CHANGELOG(Peter)
Make % operator have precedence like /(Bruce)
Add new postgres -O option to allow system table structure changes(Bruce)
Update contrib/pginterface/findoidjoins script(Tom)
Major speedup in vacuum of deleted rows with indexes(Vadim) 
Allow non-SQL functions to run different versions based on arguments(Tom)
Add -E option that shows actual queries sent by \dt and friends(Masaaki Sakaida)
Add version number in start-up banners for psql(Masaaki Sakaida)
New contrib/vacuumlo removes large objects not referenced(Peter)
New initialization for table sizes so non-vacuumed tables perform better(Tom)
Improve error messages when a connection is rejected(Tom)
Support for arrays of char() and varchar() fields(Massimo)
Overhaul of hash code to increase reliability and performance(Tom)
Update to PyGreSQL 2.4(D'Arcy)
Changed debug options so -d4 and -d5 produce different node displays(Jan)
New pg_options: pretty_plan, pretty_parse, pretty_rewritten(Jan)
Better optimization statistics for system table access(Tom)
Better handling of non-default block sizes(Massimo)
Improve GEQO optimizer memory consumption(Tom)
UNION now suppports ORDER BY of columns not in target list(Jan)
Major libpq++ improvements(Vince Vielhaber)
pg_dump now uses -z(ACL's) as default(Bruce)
backend cache, memory speedups(Tom)
have pg_dump do everything in one snapshot transaction(Vadim)
fix for large object memory leakage, fix for pg_dumping(Tom)
INET type now respects netmask for comparisons
Make VACUUM ANALYZE only use a readlock(Vadim)
Allow VIEWs on UNIONS(Jan)
pg_dump now can generate consistent snapshots on active databases(Vadim)

Source Tree Changes
-------------------
Improve port matching(Tom)
Portability fixes for SunOS
Add NT/Win32 backend port and enable dynamic loading(Magnus and Daniel Horak)
New port to Cobalt Qube(Mips) running Linux(Tatsuo)
Port to NetBSD/m68k(Mr. Mutsuki Nakajima)
Port to NetBSD/sun3(Mr. Mutsuki Nakajima)
Port to NetBSD/macppc(Toshimi Aoki)
Fix for tcl/tk configuration(Vince)
Removed CURRENT keyword for rule queries(Jan)
NT dynamic loading now works(Daniel Horak)
Add ARM32 support(Andrew McMurry)
Better support for HPUX 11 and Unixware
Improve file handling to be more uniform, prevent file descriptor leak(Tom)
New install commands for plpgsql(Jan)