Fix xslt_process() to ensure that it inserts a NULL terminator after the
[PostgreSQL.git] / doc / src / sgml / release-8.0.sgml
blobd77fa2cae3469561db55a03f0e48b299a2f9803e
1 <!-- $PostgreSQL$ -->
2 <!-- See header comment in release.sgml about typical markup -->
4 <sect1 id="release-8-0-21">
5 <title>Release 8.0.21</title>
7 <note>
8 <title>Release date</title>
9 <simpara>2009-03-16</simpara>
10 </note>
12 <para>
13 This release contains a variety of fixes from 8.0.20.
14 For information about new features in the 8.0 major release, see
15 <xref linkend="release-8-0">.
16 </para>
18 <sect2>
19 <title>Migration to Version 8.0.21</title>
21 <para>
22 A dump/restore is not required for those running 8.0.X.
23 However, if you are upgrading from a version earlier than 8.0.6,
24 see the release notes for 8.0.6.
25 </para>
27 </sect2>
29 <sect2>
30 <title>Changes</title>
32 <itemizedlist>
34 <listitem>
35 <para>
36 Prevent error recursion crashes when encoding conversion fails (Tom)
37 </para>
39 <para>
40 This change extends fixes made in the last two minor releases for
41 related failure scenarios. The previous fixes were narrowly tailored
42 for the original problem reports, but we have now recognized that
43 <emphasis>any</> error thrown by an encoding conversion function could
44 potentially lead to infinite recursion while trying to report the
45 error. The solution therefore is to disable translation and encoding
46 conversion and report the plain-ASCII form of any error message,
47 if we find we have gotten into a recursive error reporting situation.
48 (CVE-2009-0922)
49 </para>
50 </listitem>
52 <listitem>
53 <para>
54 Disallow <command>CREATE CONVERSION</> with the wrong encodings
55 for the specified conversion function (Heikki)
56 </para>
58 <para>
59 This prevents one possible scenario for encoding conversion failure.
60 The previous change is a backstop to guard against other kinds of
61 failures in the same area.
62 </para>
63 </listitem>
65 <listitem>
66 <para>
67 Fix core dump when <function>to_char()</> is given format codes that
68 are inappropriate for the type of the data argument (Tom)
69 </para>
70 </listitem>
72 <listitem>
73 <para>
74 Add <literal>MUST</> (Mauritius Island Summer Time) to the default list
75 of known timezone abbreviations (Xavier Bugaud)
76 </para>
77 </listitem>
79 </itemizedlist>
81 </sect2>
82 </sect1>
84 <sect1 id="release-8-0-20">
85 <title>Release 8.0.20</title>
87 <note>
88 <title>Release date</title>
89 <simpara>2009-02-02</simpara>
90 </note>
92 <para>
93 This release contains a variety of fixes from 8.0.19.
94 For information about new features in the 8.0 major release, see
95 <xref linkend="release-8-0">.
96 </para>
98 <sect2>
99 <title>Migration to Version 8.0.20</title>
101 <para>
102 A dump/restore is not required for those running 8.0.X.
103 However, if you are upgrading from a version earlier than 8.0.6,
104 see the release notes for 8.0.6.
105 </para>
107 </sect2>
109 <sect2>
110 <title>Changes</title>
112 <itemizedlist>
114 <listitem>
115 <para>
116 Improve handling of URLs in <function>headline()</> function (Teodor)
117 </para>
118 </listitem>
120 <listitem>
121 <para>
122 Improve handling of overlength headlines in <function>headline()</>
123 function (Teodor)
124 </para>
125 </listitem>
127 <listitem>
128 <para>
129 Prevent possible Assert failure or misconversion if an encoding
130 conversion is created with the wrong conversion function for the
131 specified pair of encodings (Tom, Heikki)
132 </para>
133 </listitem>
135 <listitem>
136 <para>
137 Avoid unnecessary locking of small tables in <command>VACUUM</>
138 (Heikki)
139 </para>
140 </listitem>
142 <listitem>
143 <para>
144 Fix uninitialized variables in <filename>contrib/tsearch2</>'s
145 <function>get_covers()</> function (Teodor)
146 </para>
147 </listitem>
149 <listitem>
150 <para>
151 Make all documentation reference <literal>pgsql-bugs</> and/or
152 <literal>pgsql-hackers</> as appropriate, instead of the
153 now-decommissioned <literal>pgsql-ports</> and <literal>pgsql-patches</>
154 mailing lists (Tom)
155 </para>
156 </listitem>
158 <listitem>
159 <para>
160 Update time zone data files to <application>tzdata</> release 2009a (for
161 Kathmandu and historical DST corrections in Switzerland, Cuba)
162 </para>
163 </listitem>
165 </itemizedlist>
167 </sect2>
168 </sect1>
170 <sect1 id="release-8-0-19">
171 <title>Release 8.0.19</title>
173 <note>
174 <title>Release date</title>
175 <simpara>2008-11-03</simpara>
176 </note>
178 <para>
179 This release contains a variety of fixes from 8.0.18.
180 For information about new features in the 8.0 major release, see
181 <xref linkend="release-8-0">.
182 </para>
184 <sect2>
185 <title>Migration to Version 8.0.19</title>
187 <para>
188 A dump/restore is not required for those running 8.0.X.
189 However, if you are upgrading from a version earlier than 8.0.6,
190 see the release notes for 8.0.6.
191 </para>
193 </sect2>
195 <sect2>
196 <title>Changes</title>
198 <itemizedlist>
200 <listitem>
201 <para>
202 Fix backend crash when the client encoding cannot represent a localized
203 error message (Tom)
204 </para>
206 <para>
207 We have addressed similar issues before, but it would still fail if
208 the <quote>character has no equivalent</> message itself couldn't
209 be converted. The fix is to disable localization and send the plain
210 ASCII error message when we detect such a situation.
211 </para>
212 </listitem>
214 <listitem>
215 <para>
216 Fix possible crash when deeply nested functions are invoked from
217 a trigger (Tom)
218 </para>
219 </listitem>
221 <listitem>
222 <para>
223 Ensure an error is reported when a newly-defined PL/pgSQL trigger
224 function is invoked as a normal function (Tom)
225 </para>
226 </listitem>
228 <listitem>
229 <para>
230 Fix incorrect tsearch2 headline generation when single query
231 item matches first word of text (Sushant Sinha)
232 </para>
233 </listitem>
235 <listitem>
236 <para>
237 Fix improper display of fractional seconds in interval values when
238 using a non-ISO datestyle in an <option>--enable-integer-datetimes</>
239 build (Ron Mayer)
240 </para>
241 </listitem>
243 <listitem>
244 <para>
245 Ensure <function>SPI_getvalue</> and <function>SPI_getbinval</>
246 behave correctly when the passed tuple and tuple descriptor have
247 different numbers of columns (Tom)
248 </para>
250 <para>
251 This situation is normal when a table has had columns added or removed,
252 but these two functions didn't handle it properly.
253 The only likely consequence is an incorrect error indication.
254 </para>
255 </listitem>
257 <listitem>
258 <para>
259 Fix <application>ecpg</>'s parsing of <command>CREATE USER</> (Michael)
260 </para>
261 </listitem>
263 <listitem>
264 <para>
265 Fix recent breakage of <literal>pg_ctl restart</> (Tom)
266 </para>
267 </listitem>
269 <listitem>
270 <para>
271 Update time zone data files to <application>tzdata</> release 2008i (for
272 DST law changes in Argentina, Brazil, Mauritius, Syria)
273 </para>
274 </listitem>
276 </itemizedlist>
278 </sect2>
279 </sect1>
281 <sect1 id="release-8-0-18">
282 <title>Release 8.0.18</title>
284 <note>
285 <title>Release date</title>
286 <simpara>2008-09-22</simpara>
287 </note>
289 <para>
290 This release contains a variety of fixes from 8.0.17.
291 For information about new features in the 8.0 major release, see
292 <xref linkend="release-8-0">.
293 </para>
295 <sect2>
296 <title>Migration to Version 8.0.18</title>
298 <para>
299 A dump/restore is not required for those running 8.0.X.
300 However, if you are upgrading from a version earlier than 8.0.6,
301 see the release notes for 8.0.6.
302 </para>
304 </sect2>
306 <sect2>
307 <title>Changes</title>
309 <itemizedlist>
311 <listitem>
312 <para>
313 Widen local lock counters from 32 to 64 bits (Tom)
314 </para>
316 <para>
317 This responds to reports that the counters could overflow in
318 sufficiently long transactions, leading to unexpected <quote>lock is
319 already held</> errors.
320 </para>
321 </listitem>
323 <listitem>
324 <para>
325 Add checks in executor startup to ensure that the tuples produced by an
326 <command>INSERT</> or <command>UPDATE</> will match the target table's
327 current rowtype (Tom)
328 </para>
330 <para>
331 <command>ALTER COLUMN TYPE</>, followed by re-use of a previously
332 cached plan, could produce this type of situation. The check protects
333 against data corruption and/or crashes that could ensue.
334 </para>
335 </listitem>
337 <listitem>
338 <para>
339 Fix datetime input functions to correctly detect integer overflow when
340 running on a 64-bit platform (Tom)
341 </para>
342 </listitem>
344 <listitem>
345 <para>
346 Improve performance of writing very long log messages to syslog (Tom)
347 </para>
348 </listitem>
350 <listitem>
351 <para>
352 Fix bug in backwards scanning of a cursor on a <literal>SELECT DISTINCT
353 ON</> query (Tom)
354 </para>
355 </listitem>
357 <listitem>
358 <para>
359 Fix planner to estimate that <literal>GROUP BY</> expressions yielding
360 boolean results always result in two groups, regardless of the
361 expressions' contents (Tom)
362 </para>
364 <para>
365 This is very substantially more accurate than the regular <literal>GROUP
366 BY</> estimate for certain boolean tests like <replaceable>col</>
367 <literal>IS NULL</>.
368 </para>
369 </listitem>
371 <listitem>
372 <para>
373 Fix PL/Tcl to behave correctly with Tcl 8.5, and to be more careful
374 about the encoding of data sent to or from Tcl (Tom)
375 </para>
376 </listitem>
378 <listitem>
379 <para>
380 Fix PL/Python to work with Python 2.5
381 </para>
383 <para>
384 This is a back-port of fixes made during the 8.2 development cycle.
385 </para>
386 </listitem>
388 <listitem>
389 <para>
390 Improve <application>pg_dump</> and <application>pg_restore</>'s
391 error reporting after failure to send a SQL command (Tom)
392 </para>
393 </listitem>
395 <listitem>
396 <para>
397 Fix <application>pg_ctl</> to properly preserve postmaster
398 command-line arguments across a <literal>restart</> (Bruce)
399 </para>
400 </listitem>
402 <listitem>
403 <para>
404 Update time zone data files to <application>tzdata</> release 2008f (for
405 DST law changes in Argentina, Bahamas, Brazil, Mauritius, Morocco,
406 Pakistan, Palestine, and Paraguay)
407 </para>
408 </listitem>
410 </itemizedlist>
412 </sect2>
413 </sect1>
415 <sect1 id="release-8-0-17">
416 <title>Release 8.0.17</title>
418 <note>
419 <title>Release date</title>
420 <simpara>2008-06-12</simpara>
421 </note>
423 <para>
424 This release contains one serious bug fix over 8.0.16.
425 For information about new features in the 8.0 major release, see
426 <xref linkend="release-8-0">.
427 </para>
429 <sect2>
430 <title>Migration to Version 8.0.17</title>
432 <para>
433 A dump/restore is not required for those running 8.0.X.
434 However, if you are upgrading from a version earlier than 8.0.6,
435 see the release notes for 8.0.6.
436 </para>
438 </sect2>
440 <sect2>
441 <title>Changes</title>
443 <itemizedlist>
445 <listitem>
446 <para>
447 Make <function>pg_get_ruledef()</> parenthesize negative constants (Tom)
448 </para>
450 <para>
451 Before this fix, a negative constant in a view or rule might be dumped
452 as, say, <literal>-42::integer</>, which is subtly incorrect: it should
453 be <literal>(-42)::integer</> due to operator precedence rules.
454 Usually this would make little difference, but it could interact with
455 another recent patch to cause
456 <productname>PostgreSQL</> to reject what had been a valid
457 <command>SELECT DISTINCT</> view query. Since this could result in
458 <application>pg_dump</> output failing to reload, it is being treated
459 as a high-priority fix. The only released versions in which dump
460 output is actually incorrect are 8.3.1 and 8.2.7.
461 </para>
462 </listitem>
464 </itemizedlist>
466 </sect2>
467 </sect1>
469 <sect1 id="release-8-0-16">
470 <title>Release 8.0.16</title>
472 <note>
473 <title>Release date</title>
474 <simpara>never released</simpara>
475 </note>
477 <para>
478 This release contains a variety of fixes from 8.0.15.
479 For information about new features in the 8.0 major release, see
480 <xref linkend="release-8-0">.
481 </para>
483 <sect2>
484 <title>Migration to Version 8.0.16</title>
486 <para>
487 A dump/restore is not required for those running 8.0.X.
488 However, if you are upgrading from a version earlier than 8.0.6,
489 see the release notes for 8.0.6.
490 </para>
492 </sect2>
494 <sect2>
495 <title>Changes</title>
497 <itemizedlist>
499 <listitem>
500 <para>
501 Fix <command>ALTER TABLE ADD COLUMN ... PRIMARY KEY</> so that the new
502 column is correctly checked to see if it's been initialized to all
503 non-nulls (Brendan Jurd)
504 </para>
506 <para>
507 Previous versions neglected to check this requirement at all.
508 </para>
509 </listitem>
511 <listitem>
512 <para>
513 Fix possible <command>CREATE TABLE</> failure when inheriting the
514 <quote>same</> constraint from multiple parent relations that
515 inherited that constraint from a common ancestor (Tom)
516 </para>
517 </listitem>
519 <listitem>
520 <para>
521 Fix conversions between ISO-8859-5 and other encodings to handle
522 Cyrillic <quote>Yo</> characters (<literal>e</> and <literal>E</> with
523 two dots) (Sergey Burladyan)
524 </para>
525 </listitem>
527 <listitem>
528 <para>
529 Fix a few datatype input functions
530 that were allowing unused bytes in their results to contain
531 uninitialized, unpredictable values (Tom)
532 </para>
534 <para>
535 This could lead to failures in which two apparently identical literal
536 values were not seen as equal, resulting in the parser complaining
537 about unmatched <literal>ORDER BY</> and <literal>DISTINCT</>
538 expressions.
539 </para>
540 </listitem>
542 <listitem>
543 <para>
544 Fix a corner case in regular-expression substring matching
545 (<literal>substring(<replaceable>string</> from
546 <replaceable>pattern</>)</literal>) (Tom)
547 </para>
549 <para>
550 The problem occurs when there is a match to the pattern overall but
551 the user has specified a parenthesized subexpression and that
552 subexpression hasn't got a match. An example is
553 <literal>substring('foo' from 'foo(bar)?')</>.
554 This should return NULL, since <literal>(bar)</> isn't matched, but
555 it was mistakenly returning the whole-pattern match instead (ie,
556 <literal>foo</>).
557 </para>
558 </listitem>
560 <listitem>
561 <para>
562 Update time zone data files to <application>tzdata</> release 2008c (for
563 DST law changes in Morocco, Iraq, Choibalsan, Pakistan, Syria, Cuba,
564 Argentina/San_Luis, and Chile)
565 </para>
566 </listitem>
568 <listitem>
569 <para>
570 Fix incorrect result from <application>ecpg</>'s
571 <function>PGTYPEStimestamp_sub()</> function (Michael)
572 </para>
573 </listitem>
575 <listitem>
576 <para>
577 Fix core dump in <filename>contrib/xml2</>'s
578 <function>xpath_table()</> function when the input query returns a
579 NULL value (Tom)
580 </para>
581 </listitem>
583 <listitem>
584 <para>
585 Fix <filename>contrib/xml2</>'s makefile to not override
586 <literal>CFLAGS</> (Tom)
587 </para>
588 </listitem>
590 <listitem>
591 <para>
592 Fix <literal>DatumGetBool</> macro to not fail with <application>gcc</>
593 4.3 (Tom)
594 </para>
596 <para>
597 This problem affects <quote>old style</> (V0) C functions that
598 return boolean. The fix is already in 8.3, but the need to
599 back-patch it was not realized at the time.
600 </para>
601 </listitem>
603 <listitem>
604 <para>
605 Fix longstanding <command>LISTEN</>/<command>NOTIFY</>
606 race condition (Tom)
607 </para>
609 <para>
610 In rare cases a session that had just executed a
611 <command>LISTEN</> might not get a notification, even though
612 one would be expected because the concurrent transaction executing
613 <command>NOTIFY</> was observed to commit later.
614 </para>
616 <para>
617 A side effect of the fix is that a transaction that has executed
618 a not-yet-committed <command>LISTEN</> command will not see any
619 row in <structname>pg_listener</> for the <command>LISTEN</>,
620 should it choose to look; formerly it would have. This behavior
621 was never documented one way or the other, but it is possible that
622 some applications depend on the old behavior.
623 </para>
624 </listitem>
626 <listitem>
627 <para>
628 Fix rare crash when an error occurs during a query using a hash index
629 (Heikki)
630 </para>
631 </listitem>
633 <listitem>
634 <para>
635 Fix input of datetime values for February 29 in years BC (Tom)
636 </para>
638 <para>
639 The former coding was mistaken about which years were leap years.
640 </para>
641 </listitem>
643 <listitem>
644 <para>
645 Fix <quote>unrecognized node type</> error in some variants of
646 <command>ALTER OWNER</> (Tom)
647 </para>
648 </listitem>
650 <listitem>
651 <para>
652 Fix <application>pg_ctl</> to correctly extract the postmaster's port
653 number from command-line options (Itagaki Takahiro, Tom)
654 </para>
656 <para>
657 Previously, <literal>pg_ctl start -w</> could try to contact the
658 postmaster on the wrong port, leading to bogus reports of startup
659 failure.
660 </para>
661 </listitem>
663 <listitem>
664 <para>
665 Use <option>-fwrapv</> to defend against possible misoptimization
666 in recent <application>gcc</> versions (Tom)
667 </para>
669 <para>
670 This is known to be necessary when building <productname>PostgreSQL</>
671 with <application>gcc</> 4.3 or later.
672 </para>
673 </listitem>
675 <listitem>
676 <para>
677 Fix display of constant expressions in <literal>ORDER BY</>
678 and <literal>GROUP BY</> (Tom)
679 </para>
681 <para>
682 An explictly casted constant would be shown incorrectly. This could
683 for example lead to corruption of a view definition during
684 dump and reload.
685 </para>
686 </listitem>
688 <listitem>
689 <para>
690 Fix <application>libpq</> to handle NOTICE messages correctly
691 during COPY OUT (Tom)
692 </para>
694 <para>
695 This failure has only been observed to occur when a user-defined
696 datatype's output routine issues a NOTICE, but there is no
697 guarantee it couldn't happen due to other causes.
698 </para>
699 </listitem>
701 </itemizedlist>
703 </sect2>
704 </sect1>
706 <sect1 id="release-8-0-15">
707 <title>Release 8.0.15</title>
709 <note>
710 <title>Release date</title>
711 <simpara>2008-01-07</simpara>
712 </note>
714 <para>
715 This release contains a variety of fixes from 8.0.14,
716 including fixes for significant security issues.
717 For information about new features in the 8.0 major release, see
718 <xref linkend="release-8-0">.
719 </para>
721 <para>
722 This is the last 8.0.X release for which the <productname>PostgreSQL</>
723 community will produce binary packages for <productname>Windows</>.
724 Windows users are encouraged to move to 8.2.X or later,
725 since there are Windows-specific fixes in 8.2.X that
726 are impractical to back-port. 8.0.X will continue to
727 be supported on other platforms.
728 </para>
730 <sect2>
731 <title>Migration to Version 8.0.15</title>
733 <para>
734 A dump/restore is not required for those running 8.0.X. However,
735 if you are upgrading from a version earlier than 8.0.6, see the release
736 notes for 8.0.6.
737 </para>
739 </sect2>
741 <sect2>
742 <title>Changes</title>
744 <itemizedlist>
746 <listitem>
747 <para>
748 Prevent functions in indexes from executing with the privileges of
749 the user running <command>VACUUM</>, <command>ANALYZE</>, etc (Tom)
750 </para>
752 <para>
753 Functions used in index expressions and partial-index
754 predicates are evaluated whenever a new table entry is made. It has
755 long been understood that this poses a risk of trojan-horse code
756 execution if one modifies a table owned by an untrustworthy user.
757 (Note that triggers, defaults, check constraints, etc. pose the
758 same type of risk.) But functions in indexes pose extra danger
759 because they will be executed by routine maintenance operations
760 such as <command>VACUUM FULL</>, which are commonly performed
761 automatically under a superuser account. For example, a nefarious user
762 can execute code with superuser privileges by setting up a
763 trojan-horse index definition and waiting for the next routine vacuum.
764 The fix arranges for standard maintenance operations
765 (including <command>VACUUM</>, <command>ANALYZE</>, <command>REINDEX</>,
766 and <command>CLUSTER</>) to execute as the table owner rather than
767 the calling user, using the same privilege-switching mechanism already
768 used for <literal>SECURITY DEFINER</> functions. To prevent bypassing
769 this security measure, execution of <command>SET SESSION
770 AUTHORIZATION</> and <command>SET ROLE</> is now forbidden within a
771 <literal>SECURITY DEFINER</> context. (CVE-2007-6600)
772 </para>
773 </listitem>
775 <listitem>
776 <para>
777 Repair assorted bugs in the regular-expression package (Tom, Will Drewry)
778 </para>
780 <para>
781 Suitably crafted regular-expression patterns could cause crashes,
782 infinite or near-infinite looping, and/or massive memory consumption,
783 all of which pose denial-of-service hazards for applications that
784 accept regex search patterns from untrustworthy sources.
785 (CVE-2007-4769, CVE-2007-4772, CVE-2007-6067)
786 </para>
787 </listitem>
789 <listitem>
790 <para>
791 Require non-superusers who use <filename>/contrib/dblink</> to use only
792 password authentication, as a security measure (Joe)
793 </para>
795 <para>
796 The fix that appeared for this in 8.0.14 was incomplete, as it plugged
797 the hole for only some <filename>dblink</> functions. (CVE-2007-6601,
798 CVE-2007-3278)
799 </para>
800 </listitem>
802 <listitem>
803 <para>
804 Update time zone data files to <application>tzdata</> release 2007k
805 (in particular, recent Argentina changes) (Tom)
806 </para>
807 </listitem>
809 <listitem>
810 <para>
811 Fix planner failure in some cases of <literal>WHERE false AND var IN
812 (SELECT ...)</> (Tom)
813 </para>
814 </listitem>
816 <listitem>
817 <para>
818 Preserve the tablespace of indexes that are
819 rebuilt by <command>ALTER TABLE ... ALTER COLUMN TYPE</> (Tom)
820 </para>
821 </listitem>
823 <listitem>
824 <para>
825 Make archive recovery always start a new WAL timeline, rather than only
826 when a recovery stop time was used (Simon)
827 </para>
829 <para>
830 This avoids a corner-case risk of trying to overwrite an existing
831 archived copy of the last WAL segment, and seems simpler and cleaner
832 than the original definition.
833 </para>
834 </listitem>
836 <listitem>
837 <para>
838 Make <command>VACUUM</> not use all of <varname>maintenance_work_mem</>
839 when the table is too small for it to be useful (Alvaro)
840 </para>
841 </listitem>
843 <listitem>
844 <para>
845 Fix potential crash in <function>translate()</> when using a multibyte
846 database encoding (Tom)
847 </para>
848 </listitem>
850 <listitem>
851 <para>
852 Fix PL/Perl to cope when platform's Perl defines type <literal>bool</>
853 as <literal>int</> rather than <literal>char</> (Tom)
854 </para>
856 <para>
857 While this could theoretically happen anywhere, no standard build of
858 Perl did things this way ... until <productname>Mac OS X</> 10.5.
859 </para>
860 </listitem>
862 <listitem>
863 <para>
864 Fix PL/Python to not crash on long exception messages (Alvaro)
865 </para>
866 </listitem>
868 <listitem>
869 <para>
870 Fix <application>pg_dump</> to correctly handle inheritance child tables
871 that have default expressions different from their parent's (Tom)
872 </para>
873 </listitem>
875 <listitem>
876 <para>
877 <application>ecpg</> parser fixes (Michael)
878 </para>
879 </listitem>
881 <listitem>
882 <para>
883 Make <filename>contrib/tablefunc</>'s <function>crosstab()</> handle
884 NULL rowid as a category in its own right, rather than crashing (Joe)
885 </para>
886 </listitem>
888 <listitem>
889 <para>
890 Fix <type>tsvector</> and <type>tsquery</> output routines to
891 escape backslashes correctly (Teodor, Bruce)
892 </para>
893 </listitem>
895 <listitem>
896 <para>
897 Fix crash of <function>to_tsvector()</> on huge input strings (Teodor)
898 </para>
899 </listitem>
901 <listitem>
902 <para>
903 Require a specific version of <productname>Autoconf</> to be used
904 when re-generating the <command>configure</> script (Peter)
905 </para>
907 <para>
908 This affects developers and packagers only. The change was made
909 to prevent accidental use of untested combinations of
910 <productname>Autoconf</> and <productname>PostgreSQL</> versions.
911 You can remove the version check if you really want to use a
912 different <productname>Autoconf</> version, but it's
913 your responsibility whether the result works or not.
914 </para>
915 </listitem>
917 </itemizedlist>
919 </sect2>
920 </sect1>
922 <sect1 id="release-8-0-14">
923 <title>Release 8.0.14</title>
925 <note>
926 <title>Release date</title>
927 <simpara>2007-09-17</simpara>
928 </note>
930 <para>
931 This release contains a variety of fixes from 8.0.13.
932 For information about new features in the 8.0 major release, see
933 <xref linkend="release-8-0">.
934 </para>
936 <sect2>
937 <title>Migration to Version 8.0.14</title>
939 <para>
940 A dump/restore is not required for those running 8.0.X. However,
941 if you are upgrading from a version earlier than 8.0.6, see the release
942 notes for 8.0.6.
943 </para>
945 </sect2>
947 <sect2>
948 <title>Changes</title>
950 <itemizedlist>
952 <listitem>
953 <para>
954 Prevent index corruption when a transaction inserts rows and
955 then aborts close to the end of a concurrent <command>VACUUM</>
956 on the same table (Tom)
957 </para>
958 </listitem>
960 <listitem>
961 <para>
962 Make <command>CREATE DOMAIN ... DEFAULT NULL</> work properly (Tom)
963 </para>
964 </listitem>
966 <listitem>
967 <para>
968 Fix excessive logging of <acronym>SSL</> error messages (Tom)
969 </para>
970 </listitem>
972 <listitem>
973 <para>
974 Fix logging so that log messages are never interleaved when using
975 the syslogger process (Andrew)
976 </para>
977 </listitem>
979 <listitem>
980 <para>
981 Fix crash when <varname>log_min_error_statement</> logging runs out
982 of memory (Tom)
983 </para>
984 </listitem>
986 <listitem>
987 <para>
988 Fix incorrect handling of some foreign-key corner cases (Tom)
989 </para>
990 </listitem>
992 <listitem>
993 <para>
994 Prevent <command>CLUSTER</> from failing
995 due to attempting to process temporary tables of other sessions (Alvaro)
996 </para>
997 </listitem>
999 <listitem>
1000 <para>
1001 Update the time zone database rules, particularly New Zealand's upcoming changes (Tom)
1002 </para>
1003 </listitem>
1005 <listitem>
1006 <para>
1007 Windows socket improvements (Magnus)
1008 </para>
1009 </listitem>
1011 <listitem>
1012 <para>
1013 Suppress timezone name (<literal>%Z</>) in log timestamps on Windows
1014 because of possible encoding mismatches (Tom)
1015 </para>
1016 </listitem>
1018 <listitem>
1019 <para>
1020 Require non-superusers who use <filename>/contrib/dblink</> to use only
1021 password authentication, as a security measure (Joe)
1022 </para>
1023 </listitem>
1025 </itemizedlist>
1027 </sect2>
1028 </sect1>
1030 <sect1 id="release-8-0-13">
1031 <title>Release 8.0.13</title>
1033 <note>
1034 <title>Release date</title>
1035 <simpara>2007-04-23</simpara>
1036 </note>
1038 <para>
1039 This release contains a variety of fixes from 8.0.12,
1040 including a security fix.
1041 For information about new features in the 8.0 major release, see
1042 <xref linkend="release-8-0">.
1043 </para>
1045 <sect2>
1046 <title>Migration to Version 8.0.13</title>
1048 <para>
1049 A dump/restore is not required for those running 8.0.X. However,
1050 if you are upgrading from a version earlier than 8.0.6, see the release
1051 notes for 8.0.6.
1052 </para>
1054 </sect2>
1056 <sect2>
1057 <title>Changes</title>
1059 <itemizedlist>
1061 <listitem>
1062 <para>
1063 Support explicit placement of the temporary-table schema within
1064 <varname>search_path</>, and disable searching it for functions
1065 and operators (Tom)
1066 </para>
1067 <para>
1068 This is needed to allow a security-definer function to set a
1069 truly secure value of <varname>search_path</>. Without it,
1070 an unprivileged SQL user can use temporary objects to execute code
1071 with the privileges of the security-definer function (CVE-2007-2138).
1072 See <command>CREATE FUNCTION</> for more information.
1073 </para>
1074 </listitem>
1076 <listitem>
1077 <para>
1078 <filename>/contrib/tsearch2</> crash fixes (Teodor)
1079 </para>
1080 </listitem>
1082 <listitem>
1083 <para>
1084 Fix potential-data-corruption bug in how <command>VACUUM FULL</> handles
1085 <command>UPDATE</> chains (Tom, Pavan Deolasee)
1086 </para>
1087 </listitem>
1089 <listitem>
1090 <para>
1091 Fix PANIC during enlargement of a hash index (bug introduced in 8.0.10)
1092 (Tom)
1093 </para>
1094 </listitem>
1096 <listitem>
1097 <para>
1098 Fix POSIX-style timezone specs to follow new USA DST rules (Tom)
1099 </para>
1100 </listitem>
1102 </itemizedlist>
1104 </sect2>
1105 </sect1>
1107 <sect1 id="release-8-0-12">
1108 <title>Release 8.0.12</title>
1110 <note>
1111 <title>Release date</title>
1112 <simpara>2007-02-07</simpara>
1113 </note>
1115 <para>
1116 This release contains one fix from 8.0.11.
1117 For information about new features in the 8.0 major release, see
1118 <xref linkend="release-8-0">.
1119 </para>
1121 <sect2>
1122 <title>Migration to Version 8.0.12</title>
1124 <para>
1125 A dump/restore is not required for those running 8.0.X. However,
1126 if you are upgrading from a version earlier than 8.0.6, see the release
1127 notes for 8.0.6.
1128 </para>
1130 </sect2>
1132 <sect2>
1133 <title>Changes</title>
1135 <itemizedlist>
1137 <listitem>
1138 <para>
1139 Remove overly-restrictive check for type length in constraints and
1140 functional indexes(Tom)
1141 </para>
1142 </listitem>
1144 </itemizedlist>
1146 </sect2>
1147 </sect1>
1149 <sect1 id="release-8-0-11">
1150 <title>Release 8.0.11</title>
1152 <note>
1153 <title>Release date</title>
1154 <simpara>2007-02-05</simpara>
1155 </note>
1157 <para>
1158 This release contains a variety of fixes from 8.0.10, including
1159 a security fix.
1160 For information about new features in the 8.0 major release, see
1161 <xref linkend="release-8-0">.
1162 </para>
1164 <sect2>
1165 <title>Migration to Version 8.0.11</title>
1167 <para>
1168 A dump/restore is not required for those running 8.0.X. However,
1169 if you are upgrading from a version earlier than 8.0.6, see the release
1170 notes for 8.0.6.
1171 </para>
1173 </sect2>
1175 <sect2>
1176 <title>Changes</title>
1178 <itemizedlist>
1180 <listitem>
1181 <para>
1182 Remove security vulnerabilities that allowed connected users
1183 to read backend memory (Tom)
1184 </para>
1185 <para>
1186 The vulnerabilities involve suppressing the normal check that a SQL
1187 function returns the data type it's declared to, and changing the
1188 data type of a table column (CVE-2007-0555, CVE-2007-0556). These
1189 errors can easily be exploited to cause a backend crash, and in
1190 principle might be used to read database content that the user
1191 should not be able to access.
1192 </para>
1193 </listitem>
1195 <listitem>
1196 <para>
1197 Fix rare bug wherein btree index page splits could fail
1198 due to choosing an infeasible split point (Heikki Linnakangas)
1199 </para>
1200 </listitem>
1202 <listitem>
1203 <para>
1204 Fix for rare Assert() crash triggered by <literal>UNION</> (Tom)
1205 </para>
1206 </listitem>
1208 <listitem>
1209 <para>
1210 Tighten security of multi-byte character processing for UTF8 sequences
1211 over three bytes long (Tom)
1212 </para>
1213 </listitem>
1215 </itemizedlist>
1217 </sect2>
1218 </sect1>
1220 <sect1 id="release-8-0-10">
1221 <title>Release 8.0.10</title>
1223 <note>
1224 <title>Release date</title>
1225 <simpara>2007-01-08</simpara>
1226 </note>
1228 <para>
1229 This release contains a variety of fixes from 8.0.9.
1230 For information about new features in the 8.0 major release, see
1231 <xref linkend="release-8-0">.
1232 </para>
1234 <sect2>
1235 <title>Migration to Version 8.0.10</title>
1237 <para>
1238 A dump/restore is not required for those running 8.0.X. However,
1239 if you are upgrading from a version earlier than 8.0.6, see the release
1240 notes for 8.0.6.
1241 </para>
1243 </sect2>
1245 <sect2>
1246 <title>Changes</title>
1248 <itemizedlist>
1250 <listitem>
1251 <para>
1252 Improve handling of <function>getaddrinfo()</> on AIX (Tom)
1253 </para>
1255 <para>
1256 This fixes a problem with starting the statistics collector,
1257 among other things.
1258 </para>
1259 </listitem>
1261 <listitem>
1262 <para>
1263 Fix <quote>failed to re-find parent key</> errors in
1264 <command>VACUUM</> (Tom)
1265 </para>
1266 </listitem>
1268 <listitem>
1269 <para>
1270 Fix race condition for truncation of a large relation across a
1271 gigabyte boundary by <command>VACUUM</> (Tom)
1272 </para>
1273 </listitem>
1275 <listitem>
1276 <para>
1277 Fix bugs affecting multi-gigabyte hash indexes (Tom)
1278 </para>
1279 </listitem>
1281 <listitem>
1282 <para>
1283 Fix possible deadlock in Windows signal handling (Teodor)
1284 </para>
1285 </listitem>
1287 <listitem>
1288 <para>
1289 Fix error when constructing an <literal>ARRAY[]</> made up of multiple
1290 empty elements (Tom)
1291 </para>
1292 </listitem>
1294 <listitem>
1295 <para>
1296 Fix ecpg memory leak during connection (Michael)
1297 </para>
1298 </listitem>
1300 <listitem>
1301 <para>
1302 <function>to_number()</> and <function>to_char(numeric)</>
1303 are now <literal>STABLE</>, not <literal>IMMUTABLE</>, for
1304 new <application>initdb</> installs (Tom)
1305 </para>
1307 <para>
1308 This is because <varname>lc_numeric</> can potentially
1309 change the output of these functions.
1310 </para>
1311 </listitem>
1313 <listitem>
1314 <para>
1315 Improve index usage of regular expressions that use parentheses (Tom)
1316 </para>
1318 <para>
1319 This improves <application>psql</> <literal>\d</> performance also.
1320 </para>
1321 </listitem>
1323 <listitem>
1324 <para>
1325 Update timezone database
1326 </para>
1328 <para>
1329 This affects Australian and Canadian daylight-savings rules in
1330 particular.
1331 </para>
1332 </listitem>
1334 </itemizedlist>
1336 </sect2>
1337 </sect1>
1339 <sect1 id="release-8-0-9">
1340 <title>Release 8.0.9</title>
1342 <note>
1343 <title>Release date</title>
1344 <simpara>2006-10-16</simpara>
1345 </note>
1347 <para>
1348 This release contains a variety of fixes from 8.0.8.
1349 For information about new features in the 8.0 major release, see
1350 <xref linkend="release-8-0">.
1351 </para>
1353 <sect2>
1354 <title>Migration to Version 8.0.9</title>
1356 <para>
1357 A dump/restore is not required for those running 8.0.X. However,
1358 if you are upgrading from a version earlier than 8.0.6, see the release
1359 notes for 8.0.6.
1360 </para>
1362 </sect2>
1364 <sect2>
1365 <title>Changes</title>
1367 <itemizedlist>
1368 <listitem><para>Fix crash when referencing <literal>NEW</> row
1369 values in rule WHERE expressions (Tom)</para></listitem>
1370 <listitem><para>Fix core dump when an untyped literal is taken as
1371 ANYARRAY</para></listitem>
1372 <listitem><para>Fix mishandling of AFTER triggers when query contains a SQL
1373 function returning multiple rows (Tom)</para></listitem>
1374 <listitem><para>Fix <command>ALTER TABLE ... TYPE</> to recheck
1375 <literal>NOT NULL</> for <literal>USING</> clause (Tom)</para></listitem>
1376 <listitem><para>Fix <function>string_to_array()</> to handle overlapping
1377 matches for the separator string</para>
1378 <para>For example, <literal>string_to_array('123xx456xxx789', 'xx')</>.
1379 </para></listitem>
1380 <listitem><para>Fix corner cases in pattern matching for
1381 <application>psql</>'s <literal>\d</> commands</para></listitem>
1382 <listitem><para>Fix index-corrupting bugs in /contrib/ltree
1383 (Teodor)</para></listitem>
1384 <listitem><para>Numerous robustness fixes in <application>ecpg</> (Joachim
1385 Wieland)</para></listitem>
1386 <listitem><para>Fix backslash escaping in /contrib/dbmirror</para></listitem>
1387 <listitem><para>Fix instability of statistics collection on Win32 (Tom, Andrew)</para></listitem>
1388 <listitem><para>Fixes for <systemitem class="osname">AIX</> and
1389 <productname>Intel</> compilers (Tom)</para></listitem>
1390 </itemizedlist>
1392 </sect2>
1393 </sect1>
1395 <sect1 id="release-8-0-8">
1396 <title>Release 8.0.8</title>
1398 <note>
1399 <title>Release date</title>
1400 <simpara>2006-05-23</simpara>
1401 </note>
1403 <para>
1404 This release contains a variety of fixes from 8.0.7,
1405 including patches for extremely serious security issues.
1406 For information about new features in the 8.0 major release, see
1407 <xref linkend="release-8-0">.
1408 </para>
1410 <sect2>
1411 <title>Migration to Version 8.0.8</title>
1413 <para>
1414 A dump/restore is not required for those running 8.0.X. However,
1415 if you are upgrading from a version earlier than 8.0.6, see the release
1416 notes for 8.0.6.
1417 </para>
1419 <para>
1420 Full security against the SQL-injection attacks described in
1421 CVE-2006-2313 and CVE-2006-2314 might require changes in application
1422 code. If you have applications that embed untrustworthy strings
1423 into SQL commands, you should examine them as soon as possible to
1424 ensure that they are using recommended escaping techniques. In
1425 most cases, applications should be using subroutines provided by
1426 libraries or drivers (such as <application>libpq</>'s
1427 <function>PQescapeStringConn()</>) to perform string escaping,
1428 rather than relying on <foreignphrase>ad hoc</> code to do it.
1429 </para>
1430 </sect2>
1432 <sect2>
1433 <title>Changes</title>
1435 <itemizedlist>
1436 <listitem><para>Change the server to reject invalidly-encoded multibyte
1437 characters in all cases (Tatsuo, Tom)</para>
1438 <para>While <productname>PostgreSQL</> has been moving in this direction for
1439 some time, the checks are now applied uniformly to all encodings and all
1440 textual input, and are now always errors not merely warnings. This change
1441 defends against SQL-injection attacks of the type described in CVE-2006-2313.
1442 </para></listitem>
1444 <listitem><para>Reject unsafe uses of <literal>\'</> in string literals</para>
1445 <para>As a server-side defense against SQL-injection attacks of the type
1446 described in CVE-2006-2314, the server now only accepts <literal>''</> and not
1447 <literal>\'</> as a representation of ASCII single quote in SQL string
1448 literals. By default, <literal>\'</> is rejected only when
1449 <varname>client_encoding</> is set to a client-only encoding (SJIS, BIG5, GBK,
1450 GB18030, or UHC), which is the scenario in which SQL injection is possible.
1451 A new configuration parameter <varname>backslash_quote</> is available to
1452 adjust this behavior when needed. Note that full security against
1453 CVE-2006-2314 might require client-side changes; the purpose of
1454 <varname>backslash_quote</> is in part to make it obvious that insecure
1455 clients are insecure.
1456 </para></listitem>
1458 <listitem><para>Modify <application>libpq</>'s string-escaping routines to be
1459 aware of encoding considerations and
1460 <varname>standard_conforming_strings</></para>
1461 <para>This fixes <application>libpq</>-using applications for the security
1462 issues described in CVE-2006-2313 and CVE-2006-2314, and also future-proofs
1463 them against the planned changeover to SQL-standard string literal syntax.
1464 Applications that use multiple <productname>PostgreSQL</> connections
1465 concurrently should migrate to <function>PQescapeStringConn()</> and
1466 <function>PQescapeByteaConn()</> to ensure that escaping is done correctly
1467 for the settings in use in each database connection. Applications that
1468 do string escaping <quote>by hand</> should be modified to rely on library
1469 routines instead.
1470 </para></listitem>
1472 <listitem><para>Fix some incorrect encoding conversion functions</para>
1473 <para><function>win1251_to_iso</>, <function>alt_to_iso</>,
1474 <function>euc_tw_to_big5</>, <function>euc_tw_to_mic</>,
1475 <function>mic_to_euc_tw</> were all broken to varying
1476 extents.
1477 </para></listitem>
1479 <listitem><para>Clean up stray remaining uses of <literal>\'</> in strings
1480 (Bruce, Jan)</para></listitem>
1482 <listitem><para>Fix bug that sometimes caused OR'd index scans to
1483 miss rows they should have returned</para></listitem>
1485 <listitem><para>Fix WAL replay for case where a btree index has been
1486 truncated</para></listitem>
1488 <listitem><para>Fix <literal>SIMILAR TO</> for patterns involving
1489 <literal>|</> (Tom)</para></listitem>
1491 <listitem><para>Fix <command>SELECT INTO</> and <command>CREATE TABLE AS</> to
1492 create tables in the default tablespace, not the base directory (Kris
1493 Jurka)</para></listitem>
1495 <listitem><para>Fix server to use custom DH SSL parameters correctly (Michael
1496 Fuhr)</para></listitem>
1498 <listitem><para>Fix for Bonjour on Intel Macs (Ashley Clark)</para></listitem>
1500 <listitem><para>Fix various minor memory leaks</para></listitem>
1502 <listitem><para>Fix problem with password prompting on some Win32 systems
1503 (Robert Kinberg)</para></listitem>
1504 </itemizedlist>
1506 </sect2>
1507 </sect1>
1509 <sect1 id="release-8-0-7">
1510 <title>Release 8.0.7</title>
1512 <note>
1513 <title>Release date</title>
1514 <simpara>2006-02-14</simpara>
1515 </note>
1517 <para>
1518 This release contains a variety of fixes from 8.0.6.
1519 For information about new features in the 8.0 major release, see
1520 <xref linkend="release-8-0">.
1521 </para>
1523 <sect2>
1524 <title>Migration to Version 8.0.7</title>
1526 <para>
1527 A dump/restore is not required for those running 8.0.X. However,
1528 if you are upgrading from a version earlier than 8.0.6, see the release
1529 notes for 8.0.6.
1530 </para>
1531 </sect2>
1533 <sect2>
1534 <title>Changes</title>
1536 <itemizedlist>
1538 <listitem><para>Fix potential crash in <command>SET
1539 SESSION AUTHORIZATION</> (CVE-2006-0553)</para>
1540 <para>An unprivileged user could crash the server process, resulting in
1541 momentary denial of service to other users, if the server has been compiled
1542 with Asserts enabled (which is not the default).
1543 Thanks to Akio Ishida for reporting this problem.
1544 </para></listitem>
1546 <listitem><para>Fix bug with row visibility logic in self-inserted
1547 rows (Tom)</para>
1548 <para>Under rare circumstances a row inserted by the current command
1549 could be seen as already valid, when it should not be. Repairs bug
1550 created in 8.0.4, 7.4.9, and 7.3.11 releases.
1551 </para></listitem>
1553 <listitem><para>Fix race condition that could lead to <quote>file already
1554 exists</> errors during pg_clog and pg_subtrans file creation
1555 (Tom)</para></listitem>
1557 <listitem><para>Fix cases that could lead to crashes if a cache-invalidation
1558 message arrives at just the wrong time (Tom)</para></listitem>
1560 <listitem><para>Properly check <literal>DOMAIN</> constraints for
1561 <literal>UNKNOWN</> parameters in prepared statements
1562 (Neil)</para></listitem>
1564 <listitem><para>Ensure <command>ALTER COLUMN TYPE</> will process
1565 <literal>FOREIGN KEY</>, <literal>UNIQUE</>, and <literal>PRIMARY KEY</>
1566 constraints in the proper order (Nakano Yoshihisa)</para></listitem>
1568 <listitem><para>Fixes to allow restoring dumps that have cross-schema
1569 references to custom operators or operator classes (Tom)</para></listitem>
1571 <listitem><para>Allow <application>pg_restore</> to continue properly after a
1572 <command>COPY</> failure; formerly it tried to treat the remaining
1573 <command>COPY</> data as SQL commands (Stephen Frost)</para></listitem>
1575 <listitem><para>Fix <application>pg_ctl</> <literal>unregister</> crash
1576 when the data directory is not specified (Magnus)</para></listitem>
1578 <listitem><para>Fix <application>ecpg</> crash on AMD64 and PPC
1579 (Neil)</para></listitem>
1581 <listitem><para>Recover properly if error occurs during argument passing
1582 in <application>PL/python</> (Neil)</para></listitem>
1584 <listitem><para>Fix <application>PL/perl</>'s handling of locales on
1585 Win32 to match the backend (Andrew)</para></listitem>
1587 <listitem><para>Fix crash when <literal>log_min_messages</> is set to
1588 <literal>DEBUG3</> or above in <filename>postgresql.conf</> on Win32
1589 (Bruce)</para></listitem>
1591 <listitem><para>Fix <application>pgxs</> <literal>-L</> library path
1592 specification for Win32, Cygwin, OS X, AIX (Bruce)</para></listitem>
1594 <listitem><para>Check that SID is enabled while checking for Win32 admin
1595 privileges (Magnus)</para></listitem>
1597 <listitem><para>Properly reject out-of-range date inputs (Kris
1598 Jurka)</para></listitem>
1600 <listitem><para>Portability fix for testing presence of <function>finite</>
1601 and <function>isinf</> during configure (Tom)</para></listitem>
1603 </itemizedlist>
1605 </sect2>
1606 </sect1>
1608 <sect1 id="release-8-0-6">
1609 <title>Release 8.0.6</title>
1611 <note>
1612 <title>Release date</title>
1613 <simpara>2006-01-09</simpara>
1614 </note>
1616 <para>
1617 This release contains a variety of fixes from 8.0.5.
1618 For information about new features in the 8.0 major release, see
1619 <xref linkend="release-8-0">.
1620 </para>
1622 <sect2>
1623 <title>Migration to Version 8.0.6</title>
1625 <para>
1626 A dump/restore is not required for those running 8.0.X. However,
1627 if you are upgrading from a version earlier than 8.0.3, see the release
1628 notes for 8.0.3.
1629 Also, you might need to <command>REINDEX</> indexes on textual
1630 columns after updating, if you are affected by the locale or
1631 <application>plperl</> issues described below.
1632 </para>
1633 </sect2>
1635 <sect2>
1636 <title>Changes</title>
1638 <itemizedlist>
1640 <listitem><para>Fix Windows code so that postmaster will continue rather
1641 than exit if there is no more room in ShmemBackendArray (Magnus)</para>
1642 <para>The previous behavior could lead to a denial-of-service situation if too
1643 many connection requests arrive close together. This applies
1644 <emphasis>only</> to the Windows port.</para></listitem>
1646 <listitem><para>Fix bug introduced in 8.0 that could allow ReadBuffer
1647 to return an already-used page as new, potentially causing loss of
1648 recently-committed data (Tom)</para></listitem>
1650 <listitem><para>Fix for protocol-level Describe messages issued
1651 outside a transaction or in a failed transaction (Tom)</para></listitem>
1653 <listitem><para>Fix character string comparison for locales that consider
1654 different character combinations as equal, such as Hungarian (Tom)</para>
1655 <para>This might require <command>REINDEX</> to fix existing indexes on
1656 textual columns.</para></listitem>
1658 <listitem><para>Set locale environment variables during postmaster startup
1659 to ensure that <application>plperl</> won't change the locale later</para>
1660 <para>This fixes a problem that occurred if the <application>postmaster</> was
1661 started with environment variables specifying a different locale than what
1662 <application>initdb</> had been told. Under these conditions, any use of
1663 <application>plperl</> was likely to lead to corrupt indexes. You might need
1664 <command>REINDEX</> to fix existing indexes on
1665 textual columns if this has happened to you.</para></listitem>
1667 <listitem><para>Allow more flexible relocation of installation
1668 directories (Tom)</para>
1669 <para>Previous releases supported relocation only if all installation
1670 directory paths were the same except for the last component.</para></listitem>
1672 <listitem><para>Fix longstanding bug in strpos() and regular expression
1673 handling in certain rarely used Asian multi-byte character sets (Tatsuo)
1674 </para></listitem>
1676 <listitem><para>Various fixes for functions returning <literal>RECORD</>s
1677 (Tom) </para></listitem>
1679 <listitem><para>Fix bug in <filename>/contrib/pgcrypto</> gen_salt,
1680 which caused it not to use all available salt space for MD5 and
1681 XDES algorithms (Marko Kreen, Solar Designer)</para>
1682 <para>Salts for Blowfish and standard DES are unaffected.</para></listitem>
1684 <listitem><para>Fix <filename>/contrib/dblink</> to throw an error,
1685 rather than crashing, when the number of columns specified is different from
1686 what's actually returned by the query (Joe)</para></listitem>
1688 </itemizedlist>
1690 </sect2>
1691 </sect1>
1693 <sect1 id="release-8-0-5">
1694 <title>Release 8.0.5</title>
1696 <note>
1697 <title>Release date</title>
1698 <simpara>2005-12-12</simpara>
1699 </note>
1701 <para>
1702 This release contains a variety of fixes from 8.0.4.
1703 For information about new features in the 8.0 major release, see
1704 <xref linkend="release-8-0">.
1705 </para>
1707 <sect2>
1708 <title>Migration to Version 8.0.5</title>
1710 <para>
1711 A dump/restore is not required for those running 8.0.X. However,
1712 if you are upgrading from a version earlier than 8.0.3, see the release
1713 notes for 8.0.3.
1714 </para>
1715 </sect2>
1717 <sect2>
1718 <title>Changes</title>
1720 <itemizedlist>
1722 <listitem><para>Fix race condition in transaction log management</para>
1723 <para>There was a narrow window in which an I/O operation could be initiated
1724 for the wrong page, leading to an Assert failure or data
1725 corruption.</para>
1726 </listitem>
1728 <listitem><para>Fix bgwriter problems after recovering from errors
1729 (Tom)</para>
1730 <para>
1731 The background writer was found to leak buffer pins after write errors.
1732 While not fatal in itself, this might lead to mysterious blockages of
1733 later VACUUM commands.
1734 </para>
1735 </listitem>
1737 <listitem><para>Prevent failure if client sends Bind protocol message
1738 when current transaction is already aborted</para></listitem>
1740 <listitem><para><filename>/contrib/ltree</> fixes (Teodor)</para></listitem>
1742 <listitem><para>AIX and HPUX compile fixes (Tom)</para></listitem>
1744 <listitem><para>Retry file reads and writes after Windows
1745 NO_SYSTEM_RESOURCES error (Qingqing Zhou)</para></listitem>
1747 <listitem><para>Fix intermittent failure when <varname>log_line_prefix</>
1748 includes <literal>%i</></para></listitem>
1750 <listitem><para>Fix <application>psql</> performance issue with long scripts
1751 on Windows (Merlin Moncure)</para></listitem>
1753 <listitem><para>Fix missing updates of <filename>pg_group</> flat
1754 file</para></listitem>
1756 <listitem><para>Fix longstanding planning error for outer joins</para>
1757 <para>This bug sometimes caused a bogus error <quote>RIGHT JOIN is
1758 only supported with merge-joinable join conditions</>.</para></listitem>
1760 <listitem><para>Postpone timezone initialization until after
1761 <filename>postmaster.pid</> is created</para>
1762 <para>This avoids confusing startup scripts that expect the pid file to appear
1763 quickly.</para></listitem>
1765 <listitem><para>Prevent core dump in <application>pg_autovacuum</> when a
1766 table has been dropped</para></listitem>
1768 <listitem><para>Fix problems with whole-row references (<literal>foo.*</>)
1769 to subquery results</para></listitem>
1770 </itemizedlist>
1772 </sect2>
1773 </sect1>
1775 <sect1 id="release-8-0-4">
1776 <title>Release 8.0.4</title>
1778 <note>
1779 <title>Release date</title>
1780 <simpara>2005-10-04</simpara>
1781 </note>
1783 <para>
1784 This release contains a variety of fixes from 8.0.3.
1785 For information about new features in the 8.0 major release, see
1786 <xref linkend="release-8-0">.
1787 </para>
1789 <sect2>
1790 <title>Migration to Version 8.0.4</title>
1792 <para>
1793 A dump/restore is not required for those running 8.0.X. However,
1794 if you are upgrading from a version earlier than 8.0.3, see the release
1795 notes for 8.0.3.
1796 </para>
1797 </sect2>
1799 <sect2>
1800 <title>Changes</title>
1802 <itemizedlist>
1803 <listitem><para>Fix error that allowed <command>VACUUM</> to remove
1804 <literal>ctid</> chains too soon, and add more checking in code that follows
1805 <literal>ctid</> links</para>
1806 <para>This fixes a long-standing problem that could cause crashes in very rare
1807 circumstances.</para></listitem>
1808 <listitem><para>Fix <type>CHAR()</> to properly pad spaces to the specified
1809 length when using a multiple-byte character set (Yoshiyuki Asaba)</para>
1810 <para>In prior releases, the padding of <type>CHAR()</> was incorrect
1811 because it only padded to the specified number of bytes without
1812 considering how many characters were stored.</para></listitem>
1813 <listitem><para>Force a checkpoint before committing <command>CREATE
1814 DATABASE</></para>
1815 <para>This should fix recent reports of <quote>index is not a btree</>
1816 failures when a crash occurs shortly after <command>CREATE
1817 DATABASE</>.</para></listitem>
1818 <listitem><para>Fix the sense of the test for read-only transaction
1819 in <command>COPY</></para>
1820 <para>The code formerly prohibited <command>COPY TO</>, where it should
1821 prohibit <command>COPY FROM</>.
1822 </para></listitem>
1823 <listitem><para>Handle consecutive embedded newlines in <command>COPY</>
1824 CSV-mode input</para></listitem>
1825 <listitem><para>Fix <function>date_trunc(week)</> for dates near year
1826 end</para></listitem>
1827 <listitem><para>Fix planning problem with outer-join ON clauses that reference
1828 only the inner-side relation</para></listitem>
1829 <listitem><para>Further fixes for <literal>x FULL JOIN y ON true</> corner
1830 cases</para></listitem>
1831 <listitem><para>Fix overenthusiastic optimization of <literal>x IN (SELECT
1832 DISTINCT ...)</> and related cases</para></listitem>
1833 <listitem><para>Fix mis-planning of queries with small <literal>LIMIT</>
1834 values due to poorly thought out <quote>fuzzy</> cost
1835 comparison</para></listitem>
1836 <listitem><para>Make <function>array_in</> and <function>array_recv</> more
1837 paranoid about validating their OID parameter</para></listitem>
1838 <listitem><para>Fix missing rows in queries like <literal>UPDATE a=... WHERE
1839 a...</> with GiST index on column <literal>a</></para></listitem>
1840 <listitem><para>Improve robustness of datetime parsing</para></listitem>
1841 <listitem><para>Improve checking for partially-written WAL
1842 pages</para></listitem>
1843 <listitem><para>Improve robustness of signal handling when SSL is
1844 enabled</para></listitem>
1845 <listitem><para>Improve MIPS and M68K spinlock code</para></listitem>
1846 <listitem><para>Don't try to open more than <literal>max_files_per_process</>
1847 files during postmaster startup</para></listitem>
1848 <listitem><para>Various memory leakage fixes</para></listitem>
1849 <listitem><para>Various portability improvements</para></listitem>
1850 <listitem><para>Update timezone data files</para></listitem>
1851 <listitem><para>Improve handling of DLL load failures on Windows</para></listitem>
1852 <listitem><para>Improve random-number generation on Windows</para></listitem>
1853 <listitem><para>Make <literal>psql -f filename</> return a nonzero exit code
1854 when opening the file fails</para></listitem>
1855 <listitem><para>Change <application>pg_dump</> to handle inherited check
1856 constraints more reliably</para></listitem>
1857 <listitem><para>Fix password prompting in <application>pg_restore</> on
1858 Windows</para></listitem>
1859 <listitem><para>Fix PL/PgSQL to handle <literal>var := var</> correctly when
1860 the variable is of pass-by-reference type</para></listitem>
1861 <listitem><para>Fix PL/Perl <literal>%_SHARED</> so it's actually
1862 shared</para></listitem>
1863 <listitem><para>Fix <filename>contrib/pg_autovacuum</> to allow sleep
1864 intervals over 2000 sec</para></listitem>
1865 <listitem><para>Update <filename>contrib/tsearch2</> to use current Snowball
1866 code</para></listitem>
1867 </itemizedlist>
1869 </sect2>
1870 </sect1>
1872 <sect1 id="release-8-0-3">
1873 <title>Release 8.0.3</title>
1875 <note>
1876 <title>Release date</title>
1877 <simpara>2005-05-09</simpara>
1878 </note>
1880 <para>
1881 This release contains a variety of fixes from 8.0.2, including several
1882 security-related issues.
1883 For information about new features in the 8.0 major release, see
1884 <xref linkend="release-8-0">.
1885 </para>
1887 <sect2>
1888 <title>Migration to Version 8.0.3</title>
1890 <para>
1891 A dump/restore is not required for those running 8.0.X. However,
1892 it is one possible way of handling two significant security problems
1893 that have been found in the initial contents of 8.0.X system
1894 catalogs. A dump/initdb/reload sequence using 8.0.3's initdb will
1895 automatically correct these problems.
1896 </para>
1898 <para>
1899 The larger security problem is that the built-in character set encoding
1900 conversion functions can be invoked from SQL commands by unprivileged
1901 users, but the functions were not designed for such use and are not
1902 secure against malicious choices of arguments. The fix involves changing
1903 the declared parameter list of these functions so that they can no longer
1904 be invoked from SQL commands. (This does not affect their normal use
1905 by the encoding conversion machinery.)
1906 </para>
1908 <para>
1909 The lesser problem is that the <filename>contrib/tsearch2</> module
1910 creates several functions that are improperly declared to return
1911 <type>internal</> when they do not accept <type>internal</> arguments.
1912 This breaks type safety for all functions using <type>internal</>
1913 arguments.
1914 </para>
1916 <para>
1917 It is strongly recommended that all installations repair these errors,
1918 either by initdb or by following the manual repair procedure given
1919 below. The errors at least allow unprivileged database users to crash
1920 their server process, and might allow unprivileged users to gain the
1921 privileges of a database superuser.
1922 </para>
1924 <para>
1925 If you wish not to do an initdb, perform the same manual repair
1926 procedures shown in the <link linkend="release-7-4-8">7.4.8 release
1927 notes</link>.
1928 </para>
1929 </sect2>
1931 <sect2>
1932 <title>Changes</title>
1934 <itemizedlist>
1935 <listitem><para>Change encoding function signature to prevent
1936 misuse</para></listitem>
1937 <listitem><para>Change <filename>contrib/tsearch2</> to avoid unsafe use of
1938 <type>INTERNAL</> function results</para></listitem>
1939 <listitem><para>Guard against incorrect second parameter to
1940 <function>record_out</></para></listitem>
1941 <listitem><para>Repair ancient race condition that allowed a transaction to be
1942 seen as committed for some purposes (eg SELECT FOR UPDATE) slightly sooner
1943 than for other purposes</para>
1944 <para>This is an extremely serious bug since it could lead to apparent
1945 data inconsistencies being briefly visible to applications.</para></listitem>
1946 <listitem><para>Repair race condition between relation extension and
1947 VACUUM</para>
1948 <para>This could theoretically have caused loss of a page's worth of
1949 freshly-inserted data, although the scenario seems of very low probability.
1950 There are no known cases of it having caused more than an Assert failure.
1951 </para></listitem>
1952 <listitem><para>Fix comparisons of <type>TIME WITH TIME ZONE</> values</para>
1953 <para>
1954 The comparison code was wrong in the case where the
1955 <literal>--enable-integer-datetimes</> configuration switch had been used.
1956 NOTE: if you have an index on a <type>TIME WITH TIME ZONE</> column,
1957 it will need to be <command>REINDEX</>ed after installing this update, because
1958 the fix corrects the sort order of column values.
1959 </para></listitem>
1960 <listitem><para>Fix <function>EXTRACT(EPOCH)</> for
1961 <type>TIME WITH TIME ZONE</> values</para></listitem>
1962 <listitem><para>Fix mis-display of negative fractional seconds in
1963 <type>INTERVAL</> values</para>
1964 <para>
1965 This error only occurred when the
1966 <literal>--enable-integer-datetimes</> configuration switch had been used.
1967 </para></listitem>
1968 <listitem><para>Fix pg_dump to dump trigger names containing <literal>%</>
1969 correctly (Neil)</para></listitem>
1970 <listitem><para>Still more 64-bit fixes for
1971 <filename>contrib/intagg</></para></listitem>
1972 <listitem><para>Prevent incorrect optimization of functions returning
1973 <type>RECORD</></para></listitem>
1974 <listitem><para>Prevent crash on <literal>COALESCE(NULL,NULL)</></para></listitem>
1975 <listitem><para>Fix Borland makefile for libpq</para></listitem>
1976 <listitem><para>Fix <filename>contrib/btree_gist</> for <type>timetz</> type
1977 (Teodor)</para></listitem>
1978 <listitem><para>Make <command>pg_ctl</> check the PID found in
1979 <filename>postmaster.pid</> to see if it is still a live
1980 process</para></listitem>
1981 <listitem><para>Fix <command>pg_dump</>/<command>pg_restore</> problems caused
1982 by addition of dump timestamps</para></listitem>
1983 <listitem><para>Fix interaction between materializing holdable cursors and
1984 firing deferred triggers during transaction commit</para></listitem>
1985 <listitem><para>Fix memory leak in SQL functions returning pass-by-reference
1986 data types</para></listitem>
1987 </itemizedlist>
1989 </sect2>
1990 </sect1>
1992 <sect1 id="release-8-0-2">
1993 <title>Release 8.0.2</title>
1995 <note>
1996 <title>Release date</title>
1997 <simpara>2005-04-07</simpara>
1998 </note>
2000 <para>
2001 This release contains a variety of fixes from 8.0.1.
2002 For information about new features in the 8.0 major release, see
2003 <xref linkend="release-8-0">.
2004 </para>
2006 <sect2>
2007 <title>Migration to Version 8.0.2</title>
2009 <para>
2010 A dump/restore is not required for those running 8.0.*.
2011 This release updates the major version number of the
2012 <productname>PostgreSQL</productname> libraries, so it might be
2013 necessary to re-link some user applications if they cannot
2014 find the properly-numbered shared library.
2015 </para>
2016 </sect2>
2018 <sect2>
2019 <title>Changes</title>
2021 <itemizedlist>
2022 <listitem><para>Increment the major version number of all interface
2023 libraries (Bruce)</para>
2024 <para>
2025 This should have been done in 8.0.0. It is required so 7.4.X versions
2026 of PostgreSQL client applications, like <application>psql</>,
2027 can be used on the same machine as 8.0.X applications. This might require
2028 re-linking user applications that use these libraries.
2029 </para></listitem>
2030 <listitem><para>Add Windows-only <varname>wal_sync_method</> setting of
2031 <option>fsync_writethrough</> (Magnus, Bruce)</para>
2032 <para>
2033 This setting causes <productname>PostgreSQL</productname> to write through
2034 any disk-drive write cache when writing to WAL.
2035 This behavior was formerly called <option>fsync</>, but was
2036 renamed because it acts quite differently from <option>fsync</> on other
2037 platforms.
2038 </para>
2039 </listitem>
2040 <listitem><para>Enable the <varname>wal_sync_method</> setting of
2041 <option>open_datasync</> on Windows, and make it the default for that
2042 platform (Magnus, Bruce)</para>
2043 <para>
2044 Because the default is no longer <option>fsync_writethrough</>,
2045 data loss is possible during a power failure if the disk drive has
2046 write caching enabled. To turn off the write cache on Windows,
2047 from the <application>Device Manager</>, choose the drive properties,
2048 then <literal>Policies</>.
2049 </para>
2050 </listitem>
2051 <listitem><para>New cache management algorithm <acronym>2Q</> replaces
2052 <acronym>ARC</> (Tom)</para>
2053 <para>
2054 This was done to avoid a pending US patent on <acronym>ARC</>. The
2055 <acronym>2Q</> code might be a few percentage points slower than
2056 <acronym>ARC</> for some work loads. A better cache management algorithm
2057 will appear in 8.1.
2058 </para></listitem>
2059 <listitem><para>Planner adjustments to improve behavior on freshly-created
2060 tables (Tom)</para></listitem>
2061 <listitem><para>Allow plpgsql to assign to an element of an array that is
2062 initially <literal>NULL</> (Tom)</para>
2063 <para>
2064 Formerly the array would remain <literal>NULL</>, but now it becomes a
2065 single-element array. The main SQL engine was changed to handle
2066 <command>UPDATE</> of a null array value this way in 8.0, but the similar
2067 case in plpgsql was overlooked.
2068 </para>
2069 </listitem>
2070 <listitem><para>Convert <literal>\r\n</> and <literal>\r</> to <literal>\n</>
2071 in plpython function bodies (Michael Fuhr)</para>
2072 <para>
2073 This prevents syntax errors when plpython code is written on a Windows or
2074 Mac client.
2075 </para>
2076 </listitem>
2077 <listitem><para>Allow SPI cursors to handle utility commands that return rows,
2078 such as <command>EXPLAIN</> (Tom)</para></listitem>
2079 <listitem><para>Fix <command>CLUSTER</> failure after <command>ALTER TABLE
2080 SET WITHOUT OIDS</> (Tom)</para></listitem>
2081 <listitem><para>Reduce memory usage of <command>ALTER TABLE ADD COLUMN</>
2082 (Neil)</para></listitem>
2083 <listitem><para>Fix <command>ALTER LANGUAGE RENAME</> (Tom)</para></listitem>
2084 <listitem><para>Document the Windows-only <literal>register</> and
2085 <literal>unregister</> options of <application>pg_ctl</> (Magnus)</para></listitem>
2086 <listitem><para>Ensure operations done during backend shutdown are counted by
2087 statistics collector</para>
2088 <para>
2089 This is expected to resolve reports of <application>pg_autovacuum</>
2090 not vacuuming the system catalogs often enough &mdash; it was not being
2091 told about catalog deletions caused by temporary table removal during
2092 backend exit.
2093 </para></listitem>
2094 <listitem><para>Change the Windows default for configuration parameter
2095 <varname>log_destination</> to <option>eventlog</> (Magnus)</para>
2096 <para>
2097 By default, a server running on Windows will now send log output to the
2098 Windows event logger rather than standard error.
2099 </para></listitem>
2100 <listitem><para>Make Kerberos authentication work on Windows (Magnus)</para></listitem>
2101 <listitem><para>Allow <command>ALTER DATABASE RENAME</> by superusers
2102 who aren't flagged as having CREATEDB privilege (Tom)</para></listitem>
2103 <listitem><para>Modify WAL log entries for <command>CREATE</> and
2104 <command>DROP DATABASE</> to not specify absolute paths (Tom)</para>
2105 <para>This allows point-in-time recovery on a different machine with possibly
2106 different database location. Note that <command>CREATE TABLESPACE</> still
2107 poses a hazard in such situations.
2108 </para></listitem>
2109 <listitem><para>Fix crash from a backend exiting with an open transaction
2110 that created a table and opened a cursor on it (Tom)</para></listitem>
2111 <listitem><para>Fix <function>array_map()</> so it can call PL functions
2112 (Tom)</para></listitem>
2113 <listitem><para>Several <filename>contrib/tsearch2</> and
2114 <filename>contrib/btree_gist</> fixes (Teodor)
2115 </para></listitem>
2116 <listitem><para>Fix crash of some <filename>contrib/pgcrypto</>
2117 functions on some platforms (Marko Kreen)</para></listitem>
2118 <listitem><para>Fix <filename>contrib/intagg</> for 64-bit platforms
2119 (Tom)</para></listitem>
2120 <listitem><para>Fix ecpg bugs in parsing of <command>CREATE</> statement
2121 (Michael)</para></listitem>
2122 <listitem><para>Work around gcc bug on powerpc and amd64 causing problems in
2123 ecpg (Christof Petig)</para></listitem>
2124 <listitem><para>Do not use locale-aware versions of <function>upper()</>,
2125 <function>lower()</>, and <function>initcap()</> when the locale is
2126 <literal>C</> (Bruce)</para>
2127 <para>
2128 This allows these functions to work on platforms that generate errors
2129 for non-7-bit data when the locale is <literal>C</>.
2130 </para></listitem>
2131 <listitem><para>Fix <function>quote_ident()</> to quote names that match keywords (Tom)</para></listitem>
2132 <listitem><para>Fix <function>to_date()</> to behave reasonably when
2133 <literal>CC</> and <literal>YY</> fields are both used (Karel)</para></listitem>
2134 <listitem><para>Prevent <function>to_char(interval)</> from failing
2135 when given a zero-month interval (Tom)</para></listitem>
2136 <listitem><para>Fix wrong week returned by <function>date_trunc('week')</>
2137 (Bruce)</para>
2138 <para>
2139 <function>date_trunc('week')</>
2140 returned the wrong year for the first few days of January in some years.
2141 </para></listitem>
2142 <listitem><para>Use the correct default mask length for class <literal>D</>
2143 addresses in <type>INET</> data types (Tom)</para></listitem>
2144 </itemizedlist>
2146 </sect2>
2147 </sect1>
2149 <sect1 id="release-8-0-1">
2150 <title>Release 8.0.1</title>
2152 <note>
2153 <title>Release date</title>
2154 <simpara>2005-01-31</simpara>
2155 </note>
2157 <para>
2158 This release contains a variety of fixes from 8.0.0, including several
2159 security-related issues.
2160 For information about new features in the 8.0 major release, see
2161 <xref linkend="release-8-0">.
2162 </para>
2164 <sect2>
2165 <title>Migration to Version 8.0.1</title>
2167 <para>
2168 A dump/restore is not required for those running 8.0.0.
2169 </para>
2170 </sect2>
2172 <sect2>
2173 <title>Changes</title>
2175 <itemizedlist>
2176 <listitem><para>Disallow <command>LOAD</> to non-superusers</para>
2177 <para>
2178 On platforms that will automatically execute initialization functions of a
2179 shared library (this includes at least Windows and ELF-based Unixen),
2180 <command>LOAD</> can be used to make the server execute arbitrary code.
2181 Thanks to NGS Software for reporting this.</para></listitem>
2182 <listitem><para>Check that creator of an aggregate function has the right to
2183 execute the specified transition functions</para>
2184 <para>
2185 This oversight made it possible to bypass denial of EXECUTE
2186 permission on a function.</para></listitem>
2187 <listitem><para>Fix security and 64-bit issues in
2188 contrib/intagg</para></listitem>
2189 <listitem><para>Add needed STRICT marking to some contrib functions (Kris
2190 Jurka)</para></listitem>
2191 <listitem><para>Avoid buffer overrun when plpgsql cursor declaration has too
2192 many parameters (Neil)</para></listitem>
2193 <listitem><para>Make <command>ALTER TABLE ADD COLUMN</> enforce domain
2194 constraints in all cases</para></listitem>
2195 <listitem><para>Fix planning error for FULL and RIGHT outer joins</para>
2196 <para>
2197 The result of the join was mistakenly supposed to be sorted the same as the
2198 left input. This could not only deliver mis-sorted output to the user, but
2199 in case of nested merge joins could give outright wrong answers.
2200 </para></listitem>
2201 <listitem><para>Improve planning of grouped aggregate queries</para></listitem>
2202 <listitem><para><command>ROLLBACK TO <replaceable>savepoint</></command>
2203 closes cursors created since the savepoint</para></listitem>
2204 <listitem><para>Fix inadequate backend stack size on Windows</para></listitem>
2205 <listitem><para>Avoid SHGetSpecialFolderPath() on Windows
2206 (Magnus)</para></listitem>
2207 <listitem><para>Fix some problems in running pg_autovacuum as a Windows
2208 service (Dave Page)</para></listitem>
2209 <listitem><para>Multiple minor bug fixes in
2210 pg_dump/pg_restore</para></listitem>
2211 <listitem><para>Fix ecpg segfault with named structs used in
2212 typedefs (Michael)</para></listitem>
2213 </itemizedlist>
2215 </sect2>
2216 </sect1>
2218 <sect1 id="release-8-0">
2219 <title>Release 8.0</title>
2221 <note>
2222 <title>Release date</title>
2223 <simpara>2005-01-19</simpara>
2224 </note>
2226 <sect2>
2227 <title>Overview</title>
2229 <para>
2230 Major changes in this release:
2231 </para>
2233 <variablelist>
2234 <varlistentry>
2235 <term>
2236 Microsoft Windows Native Server
2237 </term>
2239 <listitem>
2240 <para>
2241 This is the first <productname>PostgreSQL</productname> release
2242 to run natively on <trademark class="registered">Microsoft Windows</> as
2243 a server. It can run as a <productname>Windows</> service. This
2244 release supports NT-based Windows releases like
2245 <productname>Windows 2000 SP4</>, <productname>Windows XP</>, and
2246 <productname>Windows 2003</>. Older releases like
2247 <productname>Windows 95</>, <productname>Windows 98</>, and
2248 <productname>Windows ME</> are not supported because these operating
2249 systems do not have the infrastructure to support
2250 <productname>PostgreSQL</productname>. A separate installer
2251 project has been created to ease installation on
2252 <productname>Windows</> &mdash; see <ulink
2253 url="http://www.postgresql.org/ftp/win32/"></ulink>.
2254 </para>
2256 <para>
2257 Although tested throughout our release cycle, the Windows port
2258 does not have the benefit of years of use in production
2259 environments that <productname>PostgreSQL</productname> has on
2260 Unix platforms. Therefore it should be treated with the same
2261 level of caution as you would a new product.
2262 </para>
2264 <para>
2265 Previous releases required the Unix emulation toolkit
2266 <productname>Cygwin</> in order to run the server on Windows
2267 operating systems. <productname>PostgreSQL</productname> has
2268 supported native clients on Windows for many years.
2269 </para>
2270 </listitem>
2271 </varlistentry>
2273 <varlistentry>
2274 <term>
2275 Savepoints
2276 </term>
2278 <listitem>
2279 <para>
2280 Savepoints allow specific parts of a transaction to be aborted
2281 without affecting the remainder of the transaction. Prior
2282 releases had no such capability; there was no way to recover
2283 from a statement failure within a transaction except by
2284 aborting the whole transaction. This feature is valuable for
2285 application writers who require error recovery within a
2286 complex transaction.
2287 </para>
2288 </listitem>
2289 </varlistentry>
2291 <varlistentry>
2292 <term>
2293 Point-In-Time Recovery
2294 </term>
2296 <listitem>
2297 <para>
2298 In previous releases there was no way to recover from disk
2299 drive failure except to restore from a previous backup or use
2300 a standby replication server. Point-in-time recovery allows
2301 continuous backup of the server. You can recover either to
2302 the point of failure or to some transaction in the past.
2303 </para>
2304 </listitem>
2305 </varlistentry>
2307 <varlistentry>
2308 <term>
2309 Tablespaces
2310 </term>
2312 <listitem>
2313 <para>
2314 Tablespaces allow administrators to select different file systems
2315 for storage of individual tables, indexes, and databases.
2316 This improves performance and control over disk space
2317 usage. Prior releases used <application>initlocation</> and
2318 manual symlink management for such tasks.
2319 </para>
2320 </listitem>
2321 </varlistentry>
2323 <varlistentry>
2324 <term>
2325 Improved Buffer Management, <command>CHECKPOINT</command>,
2326 <command>VACUUM</command>
2327 </term>
2329 <listitem>
2330 <para>
2331 This release has a more intelligent buffer replacement strategy,
2332 which will make better use of available shared buffers and
2333 improve performance. The performance impact of vacuum and
2334 checkpoints is also lessened.
2335 </para>
2336 </listitem>
2337 </varlistentry>
2339 <varlistentry>
2340 <term>
2341 Change Column Types
2342 </term>
2344 <listitem>
2345 <para>
2346 A column's data type can now be changed with <command>ALTER
2347 TABLE</command>.
2348 </para>
2349 </listitem>
2350 </varlistentry>
2352 <varlistentry>
2353 <term>
2354 New Perl Server-Side Language
2355 </term>
2357 <listitem>
2358 <para>
2359 A new version of the <application>plperl</> server-side language now
2360 supports a persistent shared storage area, triggers, returning records
2361 and arrays of records, and SPI calls to access the database.
2362 </para>
2363 </listitem>
2364 </varlistentry>
2366 <varlistentry>
2367 <term>
2368 Comma-separated-value (CSV) support in <command>COPY</command>
2369 </term>
2371 <listitem>
2372 <para>
2373 <command>COPY</command> can now read and write
2374 comma-separated-value files. It has the flexibility to
2375 interpret nonstandard quoting and separation characters too.
2376 </para>
2377 </listitem>
2378 </varlistentry>
2380 </variablelist>
2381 </sect2>
2383 <sect2>
2384 <title>Migration to Version 8.0</title>
2386 <para>
2387 A dump/restore using <application>pg_dump</application> is
2388 required for those wishing to migrate data from any previous
2389 release.
2390 </para>
2392 <para>
2393 Observe the following incompatibilities:
2394 </para>
2396 <itemizedlist>
2398 <listitem>
2399 <para>
2400 In <option>READ COMMITTED</> serialization mode, volatile functions
2401 now see the results of concurrent transactions committed up to the
2402 beginning of each statement within the function, rather than up to the
2403 beginning of the interactive command that called the function.
2404 </para>
2405 </listitem>
2407 <listitem>
2408 <para>
2409 Functions declared <option>STABLE</> or <option>IMMUTABLE</> always
2410 use the snapshot of the calling query, and therefore do not see the
2411 effects of actions taken after the calling query starts, whether in
2412 their own transaction or other transactions. Such a function must be
2413 read-only, too, meaning that it cannot use any SQL commands other than
2414 <command>SELECT</>.
2415 </para>
2416 </listitem>
2418 <listitem>
2419 <para>
2420 Nondeferred <option>AFTER</> triggers are now fired immediately
2421 after completion of the triggering query, rather than upon
2422 finishing the current interactive command. This makes a
2423 difference when the triggering query occurred within a function:
2424 the trigger is invoked before the function proceeds to its next
2425 operation.
2426 </para>
2427 </listitem>
2429 <listitem>
2430 <para>
2431 Server configuration parameters <varname>virtual_host</> and
2432 <varname>tcpip_socket</> have been replaced with a more general
2433 parameter <varname>listen_addresses</>. Also, the server now listens on
2434 <literal>localhost</> by default, which eliminates the need for the
2435 <literal>-i</> postmaster switch in many scenarios.
2436 </para>
2437 </listitem>
2439 <listitem>
2440 <para>
2441 Server configuration parameters <varname>SortMem</> and
2442 <varname>VacuumMem</> have been renamed to <varname>work_mem</>
2443 and <varname>maintenance_work_mem</> to better reflect their
2444 use. The original names are still supported in
2445 <command>SET</command> and <command>SHOW</command>.
2446 </para>
2447 </listitem>
2449 <listitem>
2450 <para>
2451 Server configuration parameters <varname>log_pid</>,
2452 <varname>log_timestamp</>, and <varname>log_source_port</> have been
2453 replaced with a more general parameter <varname>log_line_prefix</>.
2454 </para>
2455 </listitem>
2457 <listitem>
2458 <para>
2459 Server configuration parameter <varname>syslog</> has been
2460 replaced with a more logical <varname>log_destination</> variable to
2461 control the log output destination.
2462 </para>
2463 </listitem>
2465 <listitem>
2466 <para>
2467 Server configuration parameter <varname>log_statement</> has been
2468 changed so it can selectively log just database modification or
2469 data definition statements. Server configuration parameter
2470 <varname>log_duration</> now prints only when <varname>log_statement</>
2471 prints the query.
2472 </para>
2473 </listitem>
2475 <listitem>
2476 <para>
2477 Server configuration parameter <varname>max_expr_depth</> parameter has
2478 been replaced with <varname>max_stack_depth</> which measures the
2479 physical stack size rather than the expression nesting depth. This
2480 helps prevent session termination due to stack overflow caused by
2481 recursive functions.
2482 </para>
2483 </listitem>
2485 <listitem>
2486 <para>
2487 The <function>length()</> function no longer counts trailing spaces in
2488 <type>CHAR(n)</> values.
2489 </para>
2490 </listitem>
2492 <listitem>
2493 <para>
2494 Casting an integer to <type>BIT(N)</> selects the rightmost N bits of the
2495 integer, not the leftmost N bits as before.
2496 </para>
2497 </listitem>
2499 <listitem>
2500 <para>
2501 Updating an element or slice of a NULL array value now produces
2502 a nonnull array result, namely an array containing
2503 just the assigned-to positions.
2504 </para>
2505 </listitem>
2507 <listitem>
2508 <para>
2509 Syntax checking of array input values has been tightened up
2510 considerably. Junk that was previously allowed in odd places with
2511 odd results now causes an error. Empty-string element values
2512 must now be written as <literal>""</>, rather than writing nothing.
2513 Also changed behavior with respect to whitespace surrounding
2514 array elements: trailing whitespace is now ignored, for symmetry
2515 with leading whitespace (which has always been ignored).
2516 </para>
2517 </listitem>
2519 <listitem>
2520 <para>
2521 Overflow in integer arithmetic operations is now detected and
2522 reported as an error.
2523 </para>
2524 </listitem>
2526 <listitem>
2527 <para>
2528 The arithmetic operators associated with the single-byte
2529 <type>"char"</> data type have been removed.
2530 </para>
2531 </listitem>
2533 <listitem>
2534 <para>
2535 The <function>extract()</> function (also called
2536 <function>date_part</>) now returns the proper year for BC dates.
2537 It previously returned one less than the correct year. The
2538 function now also returns the proper values for millennium and
2539 century.
2540 </para>
2541 </listitem>
2543 <listitem>
2544 <para>
2545 <type>CIDR</> values now must have their nonmasked bits be zero.
2546 For example, we no longer allow
2547 <literal>204.248.199.1/31</literal> as a <type>CIDR</> value. Such
2548 values should never have been accepted by
2549 <productname>PostgreSQL</productname> and will now be rejected.
2550 </para>
2551 </listitem>
2553 <listitem>
2554 <para>
2555 <command>EXECUTE</command> now returns a completion tag that
2556 matches the executed statement.
2557 </para>
2558 </listitem>
2560 <listitem>
2561 <para>
2562 <application>psql</>'s <command>\copy</> command now reads or
2563 writes to the query's <literal>stdin/stdout</>, rather than
2564 <application>psql</>'s <literal>stdin/stdout</>. The previous
2565 behavior can be accessed via new
2566 <option>pstdin</>/<option>pstdout</> parameters.
2567 </para>
2568 </listitem>
2570 <listitem>
2571 <para>
2572 The JDBC client interface has been removed from the core
2573 distribution, and is now hosted at <ulink url=
2574 "http://jdbc.postgresql.org"></ulink>.
2575 </para>
2576 </listitem>
2578 <listitem>
2579 <para>
2580 The Tcl client interface has also been removed. There are several
2581 Tcl interfaces now hosted at <ulink url=
2582 "http://gborg.postgresql.org"></ulink>.
2583 </para>
2584 </listitem>
2586 <listitem>
2587 <para>
2588 The server now uses its own time zone database, rather than the
2589 one supplied by the operating system. This will provide consistent
2590 behavior across all platforms. In most cases, there should be
2591 little noticeable difference in time zone behavior, except that
2592 the time zone names used by <command>SET</>/<command>SHOW</>
2593 <varname>TimeZone</> might be different from what your platform provides.
2594 </para>
2595 </listitem>
2597 <listitem>
2598 <para>
2599 <application>Configure</>'s threading option no longer requires
2600 users to run tests or edit configuration files; threading options
2601 are now detected automatically.
2602 </para>
2603 </listitem>
2605 <listitem>
2606 <para>
2607 Now that tablespaces have been implemented,
2608 <application>initlocation</> has been removed.
2609 </para>
2610 </listitem>
2612 <listitem>
2613 <para>
2614 The API for user-defined GiST indexes has been changed. The
2615 Union and PickSplit methods are now passed a pointer to a
2616 special <structname>GistEntryVector</structname> structure,
2617 rather than a <type>bytea</type>.
2618 </para>
2619 </listitem>
2621 </itemizedlist>
2622 </sect2>
2624 <sect2>
2625 <title>Deprecated Features</title>
2627 <para>
2628 Some aspects of <productname>PostgreSQL</productname>'s behavior
2629 have been determined to be suboptimal. For the sake of backward
2630 compatibility these have not been removed in 8.0, but they are
2631 considered deprecated and will be removed in the next major
2632 release.
2633 </para>
2635 <itemizedlist>
2636 <listitem>
2637 <para>
2638 The 8.1 release will remove the <function>to_char()</> function
2639 for intervals.
2640 </para>
2641 </listitem>
2643 <listitem>
2644 <para>
2645 The server now warns of empty strings passed to
2646 <type>oid</type>/<type>float4</type>/<type>float8</type> data
2647 types, but continues to interpret them as zeroes as before.
2648 In the next major release, empty strings will be considered
2649 invalid input for these data types.
2650 </para>
2651 </listitem>
2653 <listitem>
2654 <para>
2655 By default, tables in <productname>PostgreSQL</productname> 8.0
2656 and earlier are created with <type>OID</>s. In the next release,
2657 this will <emphasis>not</emphasis> be the case: to create a table
2658 that contains <type>OID</>s, the <option>WITH OIDS</> clause must
2659 be specified or the <varname>default_with_oids</varname>
2660 configuration parameter must be set. Users are encouraged to
2661 explicitly specify <option>WITH OIDS</> if their tables
2662 require OIDs for compatibility with future releases of
2663 <productname>PostgreSQL</productname>.
2664 </para>
2665 </listitem>
2667 </itemizedlist>
2668 </sect2>
2670 <sect2>
2671 <title>Changes</title>
2673 <para>
2674 Below you will find a detailed account of the changes between
2675 release 8.0 and the previous major release.
2676 </para>
2678 <sect3>
2679 <title>Performance Improvements</title>
2680 <itemizedlist>
2682 <listitem>
2683 <para>
2684 Support cross-data-type index usage (Tom)
2685 </para>
2686 <para>
2687 Before this change, many queries would not use an index if the data
2688 types did not match exactly. This improvement makes index usage more
2689 intuitive and consistent.
2690 </para>
2691 </listitem>
2693 <listitem>
2694 <para>
2695 New buffer replacement strategy that improves caching (Jan)
2696 </para>
2697 <para>
2698 Prior releases used a least-recently-used (LRU) cache to keep
2699 recently referenced pages in memory. The LRU algorithm
2700 did not consider the number of times a specific cache entry was
2701 accessed, so large table scans could force out useful cache pages.
2702 The new cache algorithm uses four separate lists to track most
2703 recently used and most frequently used cache pages and dynamically
2704 optimize their replacement based on the work load. This should
2705 lead to much more efficient use of the shared buffer cache.
2706 Administrators who have tested shared buffer sizes in the past
2707 should retest with this new cache replacement policy.
2708 </para>
2709 </listitem>
2711 <listitem>
2712 <para>
2713 Add subprocess to write dirty buffers periodically to reduce
2714 checkpoint writes (Jan)
2715 </para>
2716 <para>
2717 In previous releases, the checkpoint process, which runs every few
2718 minutes, would write all dirty buffers to the operating system's
2719 buffer cache then flush all dirty operating system buffers to
2720 disk. This resulted in a periodic spike in disk usage that often
2721 hurt performance. The new code uses a background writer to trickle
2722 disk writes at a steady pace so checkpoints have far fewer dirty
2723 pages to write to disk. Also, the new code does not issue a global
2724 <function>sync()</> call, but instead <function>fsync()</>s just
2725 the files written since the last checkpoint. This should improve
2726 performance and minimize degradation during checkpoints.
2727 </para>
2728 </listitem>
2730 <listitem>
2731 <para>
2732 Add ability to prolong vacuum to reduce performance impact (Jan)
2733 </para>
2734 <para>
2735 On busy systems, <command>VACUUM</command> performs many I/O
2736 requests which can hurt performance for other users. This
2737 release allows you to slow down <command>VACUUM</command> to
2738 reduce its impact on other users, though this increases the
2739 total duration of <command>VACUUM</command>.
2740 </para>
2741 </listitem>
2743 <listitem>
2744 <para>
2745 Improve B-tree index performance for duplicate keys (Dmitry Tkach, Tom)
2746 </para>
2747 <para>
2748 This improves the way indexes are scanned when many duplicate
2749 values exist in the index.
2750 </para>
2751 </listitem>
2753 <listitem>
2754 <para>
2755 Use dynamically-generated table size estimates while planning (Tom)
2756 </para>
2757 <para>
2758 Formerly the planner estimated table sizes using the values seen
2759 by the last <command>VACUUM</command> or <command>ANALYZE</command>,
2760 both as to physical table size (number of pages) and number of rows.
2761 Now, the current physical table size is obtained from the kernel,
2762 and the number of rows is estimated by multiplying the table size
2763 by the row density (rows per page) seen by the last
2764 <command>VACUUM</command> or <command>ANALYZE</command>. This should
2765 produce more reliable estimates in cases where the table size has
2766 changed significantly since the last housekeeping command.
2767 </para>
2768 </listitem>
2770 <listitem>
2771 <para>
2772 Improved index usage with <literal>OR</> clauses (Tom)
2773 </para>
2774 <para>
2775 This allows the optimizer to use indexes in statements with many OR
2776 clauses that would not have been indexed in the past. It can also use
2777 multi-column indexes where the first column is specified and the second
2778 column is part of an <literal>OR</> clause.
2779 </para>
2780 </listitem>
2782 <listitem>
2783 <para>
2784 Improve matching of partial index clauses (Tom)
2785 </para>
2786 <para>
2787 The server is now smarter about using partial indexes in queries
2788 involving complex <option>WHERE</> clauses.
2789 </para>
2790 </listitem>
2792 <listitem>
2793 <para>
2794 Improve performance of the GEQO optimizer (Tom)
2795 </para>
2796 <para>
2797 The GEQO optimizer is used to plan queries involving many tables (by
2798 default, twelve or more). This release speeds up the way queries are
2799 analyzed to decrease time spent in optimization.
2800 </para>
2801 </listitem>
2803 <listitem>
2804 <para>
2805 Miscellaneous optimizer improvements
2806 </para>
2807 <para>
2808 There is not room here to list all the minor improvements made, but
2809 numerous special cases work better than in prior releases.
2810 </para>
2811 </listitem>
2813 <listitem>
2814 <para>
2815 Improve lookup speed for C functions (Tom)
2816 </para>
2817 <para>
2818 This release uses a hash table to lookup information for dynamically
2819 loaded C functions. This improves their speed so they perform nearly as
2820 quickly as functions that are built into the server executable.
2821 </para>
2822 </listitem>
2824 <listitem>
2825 <para>
2826 Add type-specific <command>ANALYZE</command> statistics
2827 capability (Mark Cave-Ayland)
2828 </para>
2829 <para>
2830 This feature allows more flexibility in generating statistics
2831 for nonstandard data types.
2832 </para>
2833 </listitem>
2835 <listitem>
2836 <para>
2837 <command>ANALYZE</command> now collects statistics for
2838 expression indexes (Tom)
2839 </para>
2840 <para>
2841 Expression indexes (also called functional indexes) allow users to
2842 index not just columns but the results of expressions and function
2843 calls. With this release, the optimizer can gather and use statistics
2844 about the contents of expression indexes. This will greatly improve
2845 the quality of planning for queries in which an expression index is
2846 relevant.
2847 </para>
2848 </listitem>
2850 <listitem>
2851 <para>
2852 New two-stage sampling method for <command>ANALYZE</command>
2853 (Manfred Koizar)
2854 </para>
2855 <para>
2856 This gives better statistics when the density of valid rows is very
2857 different in different regions of a table.
2858 </para>
2859 </listitem>
2861 <listitem>
2862 <para>
2863 Speed up <command>TRUNCATE</command> (Tom)
2864 </para>
2865 <para>
2866 This buys back some of the performance loss observed in 7.4, while still
2867 keeping <command>TRUNCATE</command> transaction-safe.
2868 </para>
2869 </listitem>
2871 </itemizedlist>
2872 </sect3>
2875 <sect3>
2876 <title>Server Changes</title>
2877 <itemizedlist>
2879 <listitem>
2880 <para>
2881 Add WAL file archiving and point-in-time recovery (Simon Riggs)
2882 </para>
2883 </listitem>
2885 <listitem>
2886 <para>
2887 Add tablespaces so admins can control disk layout (Gavin)
2888 </para>
2889 </listitem>
2891 <listitem>
2892 <para>
2893 Add a built-in log rotation program (Andreas Pflug)
2894 </para>
2895 <para>
2896 It is now possible to log server messages conveniently without
2897 relying on either <application>syslog</> or an external log
2898 rotation program.
2899 </para>
2900 </listitem>
2902 <listitem>
2903 <para>
2904 Add new read-only server configuration parameters to show server
2905 compile-time settings: <varname>block_size</>,
2906 <varname>integer_datetimes</>, <varname>max_function_args</>,
2907 <varname>max_identifier_length</>, <varname>max_index_keys</> (Joe)
2908 </para>
2909 </listitem>
2911 <listitem>
2912 <para>
2913 Make quoting of <literal>sameuser</>, <literal>samegroup</>, and
2914 <literal>all</> remove special meaning of these terms in
2915 <filename>pg_hba.conf</> (Andrew)
2916 </para>
2917 </listitem>
2919 <listitem>
2920 <para>
2921 Use clearer IPv6 name <literal>::1/128</> for
2922 <literal>localhost</> in default <filename>pg_hba.conf</> (Andrew)
2923 </para>
2924 </listitem>
2926 <listitem>
2927 <para>
2928 Use CIDR format in <filename>pg_hba.conf</> examples (Andrew)
2929 </para>
2930 </listitem>
2932 <listitem>
2933 <para>
2934 Rename server configuration parameters <varname>SortMem</> and
2935 <varname>VacuumMem</> to <varname>work_mem</> and
2936 <varname>maintenance_work_mem</> (Old names still supported) (Tom)
2937 </para>
2938 <para>
2939 This change was made to clarify that bulk operations such as index and
2940 foreign key creation use <varname>maintenance_work_mem</>, while
2941 <varname>work_mem</> is for workspaces used during query execution.
2942 </para>
2943 </listitem>
2945 <listitem>
2946 <para>
2947 Allow logging of session disconnections using server configuration
2948 <varname>log_disconnections</> (Andrew)
2949 </para>
2950 </listitem>
2952 <listitem>
2953 <para>
2954 Add new server configuration parameter <varname>log_line_prefix</> to
2955 allow control of information emitted in each log line (Andrew)
2956 </para>
2957 <para>
2958 Available information includes user name, database name, remote IP
2959 address, and session start time.
2960 </para>
2961 </listitem>
2963 <listitem>
2964 <para>
2965 Remove server configuration parameters <varname>log_pid</>,
2966 <varname>log_timestamp</>, <varname>log_source_port</>; functionality
2967 superseded by <varname>log_line_prefix</> (Andrew)
2968 </para>
2969 </listitem>
2971 <listitem>
2972 <para>
2973 Replace the <varname>virtual_host</> and <varname>tcpip_socket</>
2974 parameters with a unified <varname>listen_addresses</> parameter
2975 (Andrew, Tom)
2976 </para>
2977 <para>
2978 <varname>virtual_host</> could only specify a single IP address to
2979 listen on. <varname>listen_addresses</> allows multiple addresses
2980 to be specified.
2981 </para>
2982 </listitem>
2984 <listitem>
2985 <para>
2986 Listen on localhost by default, which eliminates the need for the
2987 <option>-i</> postmaster switch in many scenarios (Andrew)
2988 </para>
2989 <para>
2990 Listening on localhost (<literal>127.0.0.1</>) opens no new
2991 security holes but allows configurations like Windows and JDBC,
2992 which do not support local sockets, to work without special
2993 adjustments.
2994 </para>
2995 </listitem>
2997 <listitem>
2998 <para>
2999 Remove <varname>syslog</> server configuration parameter, and add more
3000 logical <varname>log_destination</> variable to control log output
3001 location (Magnus)
3002 </para>
3003 </listitem>
3005 <listitem>
3006 <para>
3007 Change server configuration parameter <varname>log_statement</> to take
3008 values <varname>all</>, <varname>mod</>, <varname>ddl</>, or
3009 <varname>none</> to select which queries are logged (Bruce)
3010 </para>
3011 <para>
3012 This allows administrators to log only data definition changes or
3013 only data modification statements.
3014 </para>
3015 </listitem>
3017 <listitem>
3018 <para>
3019 Some logging-related configuration parameters could formerly be adjusted
3020 by ordinary users, but only in the <quote>more verbose</> direction.
3021 They are now treated more strictly: only superusers can set them.
3022 However, a superuser can use <command>ALTER USER</> to provide per-user
3023 settings of these values for non-superusers. Also, it is now possible
3024 for superusers to set values of superuser-only configuration parameters
3025 via <literal>PGOPTIONS</>.
3026 </para>
3027 </listitem>
3029 <listitem>
3030 <para>
3031 Allow configuration files to be placed outside the data directory (mlw)
3032 </para>
3033 <para>
3034 By default, configuration files are kept in the cluster's top directory.
3035 With this addition, configuration files can be placed outside the
3036 data directory, easing administration.
3037 </para>
3038 </listitem>
3040 <listitem>
3041 <para>
3042 Plan prepared queries only when first executed so constants can be
3043 used for statistics (Oliver Jowett)
3044 </para>
3045 <para>
3046 Prepared statements plan queries once and execute them many
3047 times. While prepared queries avoid the overhead of re-planning
3048 on each use, the quality of the plan suffers from not knowing the exact
3049 parameters to be used in the query. In this release, planning of
3050 unnamed prepared statements is delayed until the first execution,
3051 and the actual parameter values of that execution are used as
3052 optimization hints. This allows use of out-of-line parameter passing
3053 without incurring a performance penalty.
3054 </para>
3055 </listitem>
3057 <listitem>
3058 <para>
3059 Allow <command>DECLARE CURSOR</command> to take parameters
3060 (Oliver Jowett)
3061 </para>
3062 <para>
3063 It is now useful to issue <command>DECLARE CURSOR</command> in a
3064 <function>Parse</> message with parameters. The parameter values
3065 sent at <function>Bind</> time will be substituted into the
3066 execution of the cursor's query.
3067 </para>
3068 </listitem>
3070 <listitem>
3071 <para>
3072 Fix hash joins and aggregates of <type>inet</type> and
3073 <type>cidr</type> data types (Tom)
3074 </para>
3075 <para>
3076 Release 7.4 handled hashing of mixed <type>inet</type> and
3077 <type>cidr</type> values incorrectly. (This bug did not exist
3078 in prior releases because they wouldn't try to hash either
3079 data type.)
3080 </para>
3081 </listitem>
3083 <listitem>
3084 <para>
3085 Make <varname>log_duration</> print only when <varname>log_statement</>
3086 prints the query (Ed L.)
3087 </para>
3088 </listitem>
3090 </itemizedlist>
3091 </sect3>
3094 <sect3>
3095 <title>Query Changes</title>
3096 <itemizedlist>
3098 <listitem>
3099 <para>
3100 Add savepoints (nested transactions) (Alvaro)
3101 </para>
3102 </listitem>
3104 <listitem>
3105 <para>
3106 Unsupported isolation levels are now accepted and promoted to the
3107 nearest supported level (Peter)
3108 </para>
3109 <para>
3110 The SQL specification states that if a database doesn't support a
3111 specific isolation level, it should use the next more restrictive level.
3112 This change complies with that recommendation.
3113 </para>
3114 </listitem>
3116 <listitem>
3117 <para>
3118 Allow <command>BEGIN WORK</command> to specify transaction
3119 isolation levels like <command>START TRANSACTION</command> does
3120 (Bruce)
3121 </para>
3122 </listitem>
3124 <listitem>
3125 <para>
3126 Fix table permission checking for cases in which rules generate
3127 a query type different from the originally submitted query (Tom)
3128 </para>
3129 </listitem>
3131 <listitem>
3132 <para>
3133 Implement dollar quoting to simplify single-quote usage (Andrew, Tom,
3134 David Fetter)
3135 </para>
3136 <para>
3137 In previous releases, because single quotes had to be used to
3138 quote a function's body, the use of single quotes inside the
3139 function text required use of two single quotes or other error-prone
3140 notations. With this release we add the ability to use "dollar
3141 quoting" to quote a block of text. The ability to use different
3142 quoting delimiters at different nesting levels greatly simplifies
3143 the task of quoting correctly, especially in complex functions.
3144 Dollar quoting can be used anywhere quoted text is needed.
3145 </para>
3146 </listitem>
3148 <listitem>
3149 <para>
3150 Make <literal>CASE val WHEN compval1 THEN ...</> evaluate <literal>val</> only once (Tom)
3151 </para>
3152 <para>
3153 <option>CASE</> no longer evaluates the tested expression multiple
3154 times. This has benefits when the expression is complex or is
3155 volatile.
3156 </para>
3157 </listitem>
3159 <listitem>
3160 <para>
3161 Test <option>HAVING</> before computing target list of an
3162 aggregate query (Tom)
3163 </para>
3164 <para>
3165 Fixes improper failure of cases such as <literal>SELECT SUM(win)/SUM(lose)
3166 ... GROUP BY ... HAVING SUM(lose) &gt; 0</>. This should work but formerly
3167 could fail with divide-by-zero.
3168 </para>
3169 </listitem>
3171 <listitem>
3172 <para>
3173 Replace <varname>max_expr_depth</> parameter with
3174 <varname>max_stack_depth</> parameter, measured in kilobytes of stack
3175 size (Tom)
3176 </para>
3177 <para>
3178 This gives us a fairly bulletproof defense against crashing due to
3179 runaway recursive functions. Instead of measuring the depth of expression
3180 nesting, we now directly measure the size of the execution stack.
3181 </para>
3182 </listitem>
3184 <listitem>
3185 <para>
3186 Allow arbitrary row expressions (Tom)
3187 </para>
3188 <para>
3189 This release allows SQL expressions to contain arbitrary composite
3190 types, that is, row values. It also allows functions to more easily
3191 take rows as arguments and return row values.
3192 </para>
3193 </listitem>
3195 <listitem>
3196 <para>
3197 Allow <option>LIKE</>/<option>ILIKE</> to be used as the operator
3198 in row and subselect comparisons (Fabien Coelho)
3199 </para>
3200 </listitem>
3202 <listitem>
3203 <para>
3204 Avoid locale-specific case conversion of basic ASCII letters in
3205 identifiers and keywords (Tom)
3206 </para>
3207 <para>
3208 This solves the <quote>Turkish problem</> with mangling of words
3209 containing <literal>I</> and <literal>i</>. Folding of characters
3210 outside the 7-bit-ASCII set is still locale-aware.
3211 </para>
3212 </listitem>
3214 <listitem>
3215 <para>
3216 Improve syntax error reporting (Fabien, Tom)
3217 </para>
3218 <para>
3219 Syntax error reports are more useful than before.
3220 </para>
3221 </listitem>
3223 <listitem>
3224 <para>
3225 Change <command>EXECUTE</command> to return a completion tag
3226 matching the executed statement (Kris Jurka)
3227 </para>
3228 <para>
3229 Previous releases return an <command>EXECUTE</command> tag for
3230 any <command>EXECUTE</command> call. In this release, the tag
3231 returned will reflect the command executed.
3232 </para>
3233 </listitem>
3235 <listitem>
3236 <para>
3237 Avoid emitting <option>NATURAL CROSS JOIN</> in rule listings (Tom)
3238 </para>
3239 <para>
3240 Such a clause makes no logical sense, but in some cases the rule
3241 decompiler formerly produced this syntax.
3242 </para>
3243 </listitem>
3245 </itemizedlist>
3246 </sect3>
3249 <sect3>
3250 <title>Object Manipulation Changes</title>
3251 <itemizedlist>
3253 <listitem>
3254 <para>
3255 Add <command>COMMENT ON</> for casts, conversions, languages,
3256 operator classes, and large objects (Christopher)
3257 </para>
3258 </listitem>
3260 <listitem>
3261 <para>
3262 Add new server configuration parameter <varname>default_with_oids</> to
3263 control whether tables are created with <type>OID</>s by default (Neil)
3264 </para>
3265 <para>
3266 This allows administrators to control whether <command>CREATE
3267 TABLE</command> commands create tables with or without <type>OID</>
3268 columns by default. (Note: the current factory default setting for
3269 <varname>default_with_oids</> is <literal>TRUE</>, but the default
3270 will become <literal>FALSE</> in future releases.)
3271 </para>
3272 </listitem>
3274 <listitem>
3275 <para>
3276 Add <option>WITH</> / <option>WITHOUT OIDS</> clause to
3277 <command>CREATE TABLE AS</command> (Neil)
3278 </para>
3279 </listitem>
3281 <listitem>
3282 <para>
3283 Allow <command>ALTER TABLE DROP COLUMN</> to drop an <type>OID</>
3284 column (<command>ALTER TABLE SET WITHOUT OIDS</> still works)
3285 (Tom)
3286 </para>
3287 </listitem>
3289 <listitem>
3290 <para>
3291 Allow composite types as table columns (Tom)
3292 </para>
3293 </listitem>
3295 <listitem>
3296 <para>
3297 Allow <command>ALTER ... ADD COLUMN</> with defaults and
3298 <option>NOT NULL</> constraints; works per SQL spec (Rod)
3299 </para>
3300 <para>
3301 It is now possible for <option>ADD COLUMN</> to create a column
3302 that is not initially filled with NULLs, but with a specified
3303 default value.
3304 </para>
3305 </listitem>
3307 <listitem>
3308 <para>
3309 Add <command>ALTER COLUMN TYPE</> to change column's type (Rod)
3310 </para>
3311 <para>
3312 It is now possible to alter a column's data type without dropping
3313 and re-adding the column.
3314 </para>
3315 </listitem>
3317 <listitem>
3318 <para>
3319 Allow multiple <command>ALTER</> actions in a single <command>ALTER
3320 TABLE</command> command (Rod)
3321 </para>
3322 <para>
3323 This is particularly useful for <command>ALTER</> commands that
3324 rewrite the table (which include <option>ALTER COLUMN TYPE</> and
3325 <option>ADD COLUMN</> with a default). By grouping
3326 <command>ALTER</> commands together, the table need be rewritten
3327 only once.
3328 </para>
3329 </listitem>
3331 <listitem>
3332 <para>
3333 Allow <command>ALTER TABLE</command> to add <type>SERIAL</type>
3334 columns (Tom)
3335 </para>
3336 <para>
3337 This falls out from the new capability of specifying defaults for new
3338 columns.
3339 </para>
3340 </listitem>
3342 <listitem>
3343 <para>
3344 Allow changing the owners of aggregates, conversions, databases,
3345 functions, operators, operator classes, schemas, types, and tablespaces
3346 (Christopher, Euler Taveira de Oliveira)
3347 </para>
3348 <para>
3349 Previously this required modifying the system tables directly.
3350 </para>
3351 </listitem>
3353 <listitem>
3354 <para>
3355 Allow temporary object creation to be limited to <option>SECURITY
3356 DEFINER</> functions (Sean Chittenden)
3357 </para>
3358 </listitem>
3360 <listitem>
3361 <para>
3362 Add <option>ALTER TABLE ... SET WITHOUT CLUSTER</> (Christopher)
3363 </para>
3364 <para>
3365 Prior to this release, there was no way to clear an auto-cluster
3366 specification except to modify the system tables.
3367 </para>
3368 </listitem>
3370 <listitem>
3371 <para>
3372 Constraint/Index/<type>SERIAL</> names are now
3373 <replaceable>table_column_type</>
3374 with numbers appended to guarantee uniqueness within the schema
3375 (Tom)
3376 </para>
3377 <para>
3378 The SQL specification states that such names should be unique
3379 within a schema.
3380 </para>
3381 </listitem>
3383 <listitem>
3384 <para>
3385 Add <function>pg_get_serial_sequence()</> to return a
3386 <type>SERIAL</> column's sequence name (Christopher)
3387 </para>
3388 <para>
3389 This allows automated scripts to reliably find the <type>SERIAL</>
3390 sequence name.
3391 </para>
3392 </listitem>
3394 <listitem>
3395 <para>
3396 Warn when primary/foreign key data type mismatch requires costly lookup
3397 </para>
3398 </listitem>
3400 <listitem>
3401 <para>
3402 New <command>ALTER INDEX</> command to allow moving of indexes
3403 between tablespaces (Gavin)
3404 </para>
3405 </listitem>
3407 <listitem>
3408 <para>
3409 Make <command>ALTER TABLE OWNER</> change dependent sequence
3410 ownership too (Alvaro)
3411 </para>
3412 </listitem>
3415 </itemizedlist>
3416 </sect3>
3419 <sect3>
3420 <title>Utility Command Changes</title>
3421 <itemizedlist>
3423 <listitem>
3424 <para>
3425 Allow <command>CREATE SCHEMA</command> to create triggers,
3426 indexes, and sequences (Neil)
3427 </para>
3428 </listitem>
3430 <listitem>
3431 <para>
3432 Add <option>ALSO</> keyword to <command>CREATE RULE</command> (Fabien
3433 Coelho)
3434 </para>
3435 <para>
3436 This allows <option>ALSO</> to be added to rule creation to contrast it with
3437 <option>INSTEAD</> rules.
3438 </para>
3439 </listitem>
3441 <listitem>
3442 <para>
3443 Add <option>NOWAIT</> option to <command>LOCK</command> (Tatsuo)
3444 </para>
3445 <para>
3446 This allows the <command>LOCK</command> command to fail if it
3447 would have to wait for the requested lock.
3448 </para>
3449 </listitem>
3451 <listitem>
3452 <para>
3453 Allow <command>COPY</command> to read and write
3454 comma-separated-value (CSV) files (Andrew, Bruce)
3455 </para>
3456 </listitem>
3458 <listitem>
3459 <para>
3460 Generate error if the <command>COPY</command> delimiter and NULL
3461 string conflict (Bruce)
3462 </para>
3463 </listitem>
3465 <listitem>
3466 <para>
3467 <command>GRANT</command>/<command>REVOKE</command> behavior
3468 follows the SQL spec more closely
3469 </para>
3470 </listitem>
3472 <listitem>
3473 <para>
3474 Avoid locking conflict between <command>CREATE INDEX</command>
3475 and <command>CHECKPOINT</command> (Tom)
3476 </para>
3477 <para>
3478 In 7.3 and 7.4, a long-running B-tree index build could block concurrent
3479 <command>CHECKPOINT</>s from completing, thereby causing WAL bloat because the
3480 WAL log could not be recycled.
3481 </para>
3482 </listitem>
3484 <listitem>
3485 <para>
3486 Database-wide <command>ANALYZE</command> does not hold locks
3487 across tables (Tom)
3488 </para>
3489 <para>
3490 This reduces the potential for deadlocks against other backends
3491 that want exclusive locks on tables. To get the benefit of this
3492 change, do not execute database-wide <command>ANALYZE</command>
3493 inside a transaction block (<command>BEGIN</command> block); it
3494 must be able to commit and start a new transaction for each
3495 table.
3496 </para>
3497 </listitem>
3499 <listitem>
3500 <para>
3501 <command>REINDEX</command> does not exclusively lock the index's
3502 parent table anymore
3503 </para>
3504 <para>
3505 The index itself is still exclusively locked, but readers of the
3506 table can continue if they are not using the particular index
3507 being rebuilt.
3508 </para>
3509 </listitem>
3511 <listitem>
3512 <para>
3513 Erase MD5 user passwords when a user is renamed (Bruce)
3514 </para>
3515 <para>
3516 <productname>PostgreSQL</productname> uses the user name as salt
3517 when encrypting passwords via MD5. When a user's name is changed,
3518 the salt will no longer match the stored MD5 password, so the
3519 stored password becomes useless. In this release a notice is
3520 generated and the password is cleared. A new password must then
3521 be assigned if the user is to be able to log in with a password.
3522 </para>
3523 </listitem>
3525 <listitem>
3526 <para>
3527 New <application>pg_ctl</> <option>kill</> option for Windows (Andrew)
3528 </para>
3529 <para>
3530 Windows does not have a <literal>kill</> command to send signals to
3531 backends so this capability was added to <application>pg_ctl</>.
3532 </para>
3533 </listitem>
3535 <listitem>
3536 <para>
3537 Information schema improvements
3538 </para>
3539 </listitem>
3541 <listitem>
3542 <para>
3543 Add <option>--pwfile</> option to
3544 <application>initdb</application> so the initial password can be
3545 set by GUI tools (Magnus)
3546 </para>
3547 </listitem>
3549 <listitem>
3550 <para>
3551 Detect locale/encoding mismatch in
3552 <application>initdb</application> (Peter)
3553 </para>
3554 </listitem>
3556 <listitem>
3557 <para>
3558 Add <option>register</> command to <application>pg_ctl</> to
3559 register Windows operating system service (Dave Page)
3560 </para>
3561 </listitem>
3563 </itemizedlist>
3564 </sect3>
3567 <sect3>
3568 <title>Data Type and Function Changes</title>
3569 <itemizedlist>
3571 <listitem>
3572 <para>
3573 More complete support for composite types (row types) (Tom)
3574 </para>
3575 <para>
3576 Composite values can be used in many places where only scalar values
3577 worked before.
3578 </para>
3579 </listitem>
3581 <listitem>
3582 <para>
3583 Reject nonrectangular array values as erroneous (Joe)
3584 </para>
3585 <para>
3586 Formerly, <function>array_in</> would silently build a
3587 surprising result.
3588 </para>
3589 </listitem>
3591 <listitem>
3592 <para>
3593 Overflow in integer arithmetic operations is now detected (Tom)
3594 </para>
3595 </listitem>
3597 <listitem>
3598 <para>
3599 The arithmetic operators associated with the single-byte
3600 <type>"char"</> data type have been removed.
3601 </para>
3602 <para>
3603 Formerly, the parser would select these operators in many situations
3604 where an <quote>unable to select an operator</> error would be more
3605 appropriate, such as <literal>null * null</>. If you actually want
3606 to do arithmetic on a <type>"char"</> column, you can cast it to
3607 integer explicitly.
3608 </para>
3609 </listitem>
3611 <listitem>
3612 <para>
3613 Syntax checking of array input values considerably tightened up (Joe)
3614 </para>
3615 <para>
3616 Junk that was previously allowed in odd places with odd results
3617 now causes an <literal>ERROR</>, for example, non-whitespace
3618 after the closing right brace.
3619 </para>
3620 </listitem>
3622 <listitem>
3623 <para>
3624 Empty-string array element values must now be written as
3625 <literal>""</>, rather than writing nothing (Joe)
3626 </para>
3627 <para>
3628 Formerly, both ways of writing an empty-string element value were
3629 allowed, but now a quoted empty string is required. The case where
3630 nothing at all appears will probably be considered to be a NULL
3631 element value in some future release.
3632 </para>
3633 </listitem>
3635 <listitem>
3636 <para>
3637 Array element trailing whitespace is now ignored (Joe)
3638 </para>
3639 <para>
3640 Formerly leading whitespace was ignored, but trailing whitespace
3641 between an element value and the delimiter or right brace was
3642 significant. Now trailing whitespace is also ignored.
3643 </para>
3644 </listitem>
3646 <listitem>
3647 <para>
3648 Emit array values with explicit array bounds when lower bound is not one
3649 (Joe)
3650 </para>
3651 </listitem>
3653 <listitem>
3654 <para>
3655 Accept <literal>YYYY-monthname-DD</> as a date string (Tom)
3656 </para>
3657 </listitem>
3659 <listitem>
3660 <para>
3661 Make <function>netmask</> and <function>hostmask</> functions
3662 return maximum-length mask length (Tom)
3663 </para>
3664 </listitem>
3666 <listitem>
3667 <para>
3668 Change factorial function to return <type>numeric</type> (Gavin)
3669 </para>
3670 <para>
3671 Returning <type>numeric</type> allows the factorial function to
3672 work for a wider range of input values.
3673 </para>
3674 </listitem>
3676 <listitem>
3677 <para>
3678 <function>to_char</>/<function>to_date()</> date conversion
3679 improvements (Kurt Roeckx, Fabien Coelho)
3680 </para>
3681 </listitem>
3683 <listitem>
3684 <para>
3685 Make <function>length()</> disregard trailing spaces in
3686 <type>CHAR(n)</> (Gavin)
3687 </para>
3688 <para>
3689 This change was made to improve consistency: trailing spaces are
3690 semantically insignificant in <type>CHAR(n)</> data, so they
3691 should not be counted by <function>length()</>.
3692 </para>
3693 </listitem>
3695 <listitem>
3696 <para>
3697 Warn about empty string being passed to
3698 <type>OID</>/<type>float4</>/<type>float8</> data types (Neil)
3699 </para>
3700 <para>
3701 8.1 will throw an error instead.
3702 </para>
3703 </listitem>
3705 <listitem>
3706 <para>
3707 Allow leading or trailing whitespace in
3708 <type>int2</>/<type>int4</>/<type>int8</>/<type>float4</>/<type>float8</>
3709 input routines
3710 (Neil)
3711 </para>
3712 </listitem>
3714 <listitem>
3715 <para>
3716 Better support for IEEE <literal>Infinity</> and <literal>NaN</>
3717 values in <type>float4</type>/<type>float8</type> (Neil)
3718 </para>
3719 <para>
3720 These should now work on all platforms that support IEEE-compliant
3721 floating point arithmetic.
3722 </para>
3723 </listitem>
3725 <listitem>
3726 <para>
3727 Add <option>week</> option to <function>date_trunc()</> (Robert Creager)
3728 </para>
3729 </listitem>
3731 <listitem>
3732 <para>
3733 Fix <function>to_char</function> for <literal>1 BC</>
3734 (previously it returned <literal>1 AD</>) (Bruce)
3735 </para>
3736 </listitem>
3738 <listitem>
3739 <para>
3740 Fix <function>date_part(year)</> for BC dates (previously it
3741 returned one less than the correct year) (Bruce)
3742 </para>
3743 </listitem>
3745 <listitem>
3746 <para>
3747 Fix <function>date_part()</> to return the proper millennium and
3748 century (Fabien Coelho)
3749 </para>
3750 <para>
3751 In previous versions, the century and millennium results had a wrong
3752 number and started in the wrong year, as compared to standard
3753 reckoning of such things.
3754 </para>
3755 </listitem>
3757 <listitem>
3758 <para>
3759 Add <function>ceiling()</> as an alias for <function>ceil()</>,
3760 and <function>power()</> as an alias for <function>pow()</> for
3761 standards compliance (Neil)
3762 </para>
3763 </listitem>
3765 <listitem>
3766 <para>
3767 Change <function>ln()</>, <function>log()</>,
3768 <function>power()</>, and <function>sqrt()</> to emit the correct
3769 <literal>SQLSTATE</> error codes for certain error conditions, as
3770 specified by SQL:2003 (Neil)
3771 </para>
3772 </listitem>
3774 <listitem>
3775 <para>
3776 Add <function>width_bucket()</> function as defined by SQL:2003 (Neil)
3777 </para>
3778 </listitem>
3780 <listitem>
3781 <para>
3782 Add <function>generate_series()</> functions to simplify working
3783 with numeric sets (Joe)
3784 </para>
3785 </listitem>
3787 <listitem>
3788 <para>
3789 Fix <function>upper/lower/initcap()</> functions to work with
3790 multibyte encodings (Tom)
3791 </para>
3792 </listitem>
3794 <listitem>
3795 <para>
3796 Add boolean and bitwise integer <option>AND</>/<option>OR</>
3797 aggregates (Fabien Coelho)
3798 </para>
3799 </listitem>
3801 <listitem>
3802 <para>
3803 New session information functions to return network addresses for client
3804 and server (Sean Chittenden)
3805 </para>
3806 </listitem>
3808 <listitem>
3809 <para>
3810 Add function to determine the area of a closed path (Sean Chittenden)
3811 </para>
3812 </listitem>
3814 <listitem>
3815 <para>
3816 Add function to send cancel request to other backends (Magnus)
3817 </para>
3818 </listitem>
3820 <listitem>
3821 <para>
3822 Add <type>interval</> plus <type>datetime</> operators (Tom)
3823 </para>
3824 <para>
3825 The reverse ordering, <type>datetime</> plus <type>interval</>,
3826 was already supported, but both are required by the SQL standard.
3827 </para>
3828 </listitem>
3830 <listitem>
3831 <para>
3832 Casting an integer to <type>BIT(N)</> selects the rightmost N bits
3833 of the integer
3834 (Tom)
3835 </para>
3836 <para>
3837 In prior releases, the leftmost N bits were selected, but this was
3838 deemed unhelpful, not to mention inconsistent with casting from bit
3839 to int.
3840 </para>
3841 </listitem>
3843 <listitem>
3844 <para>
3845 Require <type>CIDR</> values to have all nonmasked bits be zero
3846 (Kevin Brintnall)
3847 </para>
3848 </listitem>
3850 </itemizedlist>
3851 </sect3>
3854 <sect3>
3855 <title>Server-Side Language Changes</title>
3856 <itemizedlist>
3858 <listitem>
3859 <para>
3860 In <literal>READ COMMITTED</> serialization mode, volatile functions
3861 now see the results of concurrent transactions committed up to the
3862 beginning of each statement within the function, rather than up to the
3863 beginning of the interactive command that called the function.
3864 </para>
3865 </listitem>
3867 <listitem>
3868 <para>
3869 Functions declared <literal>STABLE</> or <literal>IMMUTABLE</> always
3870 use the snapshot of the calling query, and therefore do not see the
3871 effects of actions taken after the calling query starts, whether in
3872 their own transaction or other transactions. Such a function must be
3873 read-only, too, meaning that it cannot use any SQL commands other than
3874 <command>SELECT</>. There is a considerable performance gain from
3875 declaring a function <literal>STABLE</> or <literal>IMMUTABLE</>
3876 rather than <literal>VOLATILE</>.
3877 </para>
3878 </listitem>
3880 <listitem>
3881 <para>
3882 Nondeferred <option>AFTER</> triggers are now fired immediately
3883 after completion of the triggering query, rather than upon
3884 finishing the current interactive command. This makes a difference
3885 when the triggering query occurred within a function: the trigger
3886 is invoked before the function proceeds to its next operation. For
3887 example, if a function inserts a new row into a table, any
3888 nondeferred foreign key checks occur before proceeding with the
3889 function.
3890 </para>
3891 </listitem>
3893 <listitem>
3894 <para>
3895 Allow function parameters to be declared with names (Dennis Bj&ouml;rklund)
3896 </para>
3897 <para>
3898 This allows better documentation of functions. Whether the names
3899 actually do anything depends on the specific function language
3900 being used.
3901 </para>
3902 </listitem>
3904 <listitem>
3905 <para>
3906 Allow PL/pgSQL parameter names to be referenced in the function (Dennis Bj&ouml;rklund)
3907 </para>
3908 <para>
3909 This basically creates an automatic alias for each named parameter.
3910 </para>
3911 </listitem>
3913 <listitem>
3914 <para>
3915 Do minimal syntax checking of PL/pgSQL functions at creation time (Tom)
3916 </para>
3917 <para>
3918 This allows us to catch simple syntax errors sooner.
3919 </para>
3920 </listitem>
3922 <listitem>
3923 <para>
3924 More support for composite types (row and record variables) in PL/pgSQL
3925 </para>
3926 <para>
3927 For example, it now works to pass a rowtype variable to another function
3928 as a single variable.
3929 </para>
3930 </listitem>
3932 <listitem>
3933 <para>
3934 Default values for PL/pgSQL variables can now reference previously
3935 declared variables
3936 </para>
3937 </listitem>
3939 <listitem>
3940 <para>
3941 Improve parsing of PL/pgSQL FOR loops (Tom)
3942 </para>
3943 <para>
3944 Parsing is now driven by presence of <literal>".."</> rather than
3945 data type of <option>FOR</> variable. This makes no difference for
3946 correct functions, but should result in more understandable error
3947 messages when a mistake is made.
3948 </para>
3949 </listitem>
3951 <listitem>
3952 <para>
3953 Major overhaul of PL/Perl server-side language (Command Prompt, Andrew Dunstan)
3954 </para>
3955 </listitem>
3957 <listitem>
3958 <para>
3959 In PL/Tcl, SPI commands are now run in subtransactions. If an error
3960 occurs, the subtransaction is cleaned up and the error is reported
3961 as an ordinary Tcl error, which can be trapped with <literal>catch</>.
3962 Formerly, it was not possible to catch such errors.
3963 </para>
3964 </listitem>
3966 <listitem>
3967 <para>
3968 Accept <command>ELSEIF</> in PL/pgSQL (Neil)
3969 </para>
3970 <para>
3971 Previously PL/pgSQL only allowed <command>ELSIF</>, but many people
3972 are accustomed to spelling this keyword <command>ELSEIF</>.
3973 </para>
3974 </listitem>
3976 </itemizedlist>
3977 </sect3>
3980 <sect3>
3981 <title><application>psql</> Changes</title>
3982 <itemizedlist>
3984 <listitem>
3985 <para>
3986 Improve <application>psql</> information display about database
3987 objects (Christopher)
3988 </para>
3989 </listitem>
3991 <listitem>
3992 <para>
3993 Allow <application>psql</> to display group membership in
3994 <command>\du</> and <command>\dg</> (Markus Bertheau)
3995 </para>
3996 </listitem>
3998 <listitem>
3999 <para>
4000 Prevent <application>psql</> <command>\dn</command> from showing
4001 temporary schemas (Bruce)
4002 </para>
4003 </listitem>
4005 <listitem>
4006 <para>
4007 Allow <application>psql</> to handle tilde user expansion for file
4008 names (Zach Irmen)
4009 </para>
4010 </listitem>
4012 <listitem>
4013 <para>
4014 Allow <application>psql</> to display fancy prompts, including
4015 color, via <application>readline</> (Reece Hart, Chet Ramey)
4016 </para>
4017 </listitem>
4019 <listitem>
4020 <para>
4021 Make <application>psql</> <command>\copy</> match <command>COPY</command> command syntax
4022 fully (Tom)
4023 </para>
4024 </listitem>
4026 <listitem>
4027 <para>
4028 Show the location of syntax errors (Fabien Coelho, Tom)
4029 </para>
4030 </listitem>
4032 <listitem>
4033 <para>
4034 Add <command>CLUSTER</command> information to <application>psql</>
4035 <command>\d</> display
4036 (Bruce)
4037 </para>
4038 </listitem>
4040 <listitem>
4041 <para>
4042 Change <application>psql</> <command>\copy stdin/stdout</> to read
4043 from command input/output (Bruce)
4044 </para>
4045 </listitem>
4047 <listitem>
4048 <para>
4049 Add <option>pstdin</>/<option>pstdout</> to read from
4050 <application>psql</>'s <literal>stdin</>/<literal>stdout</> (Mark
4051 Feit)
4052 </para>
4053 </listitem>
4055 <listitem>
4056 <para>
4057 Add global <application>psql</> configuration file, <filename>psqlrc.sample</filename>
4058 (Bruce)
4059 </para>
4060 <para>
4061 This allows a central file where global <application>psql</> startup commands can
4062 be stored.
4063 </para>
4064 </listitem>
4066 <listitem>
4067 <para>
4068 Have <application>psql</> <command>\d+</> indicate if the table
4069 has an <type>OID</> column (Neil)
4070 </para>
4071 </listitem>
4073 <listitem>
4074 <para>
4075 On Windows, use binary mode in <application>psql</> when reading files so control-Z
4076 is not seen as end-of-file
4077 </para>
4078 </listitem>
4080 <listitem>
4081 <para>
4082 Have <command>\dn+</> show permissions and description for schemas (Dennis
4083 Bj&ouml;rklund)
4084 </para>
4085 </listitem>
4087 <listitem>
4088 <para>
4089 Improve tab completion support (Stefan Kaltenbrunn, Greg Sabino Mullane)
4090 </para>
4091 </listitem>
4093 <listitem>
4094 <para>
4095 Allow boolean settings to be set using upper or lower case (Michael Paesold)
4096 </para>
4097 </listitem>
4099 </itemizedlist>
4100 </sect3>
4103 <sect3>
4104 <title><application>pg_dump</> Changes</title>
4105 <itemizedlist>
4107 <listitem>
4108 <para>
4109 Use dependency information to improve the reliability of
4110 <application>pg_dump</> (Tom)
4111 </para>
4112 <para>
4113 This should solve the longstanding problems with related objects
4114 sometimes being dumped in the wrong order.
4115 </para>
4116 </listitem>
4118 <listitem>
4119 <para>
4120 Have <application>pg_dump</> output objects in alphabetical order if possible (Tom)
4121 </para>
4122 <para>
4123 This should make it easier to identify changes between
4124 dump files.
4125 </para>
4126 </listitem>
4128 <listitem>
4129 <para>
4130 Allow <application>pg_restore</> to ignore some SQL errors (Fabien Coelho)
4131 </para>
4132 <para>
4133 This makes <application>pg_restore</>'s behavior similar to the
4134 results of feeding a <application>pg_dump</> output script to
4135 <application>psql</>. In most cases, ignoring errors and plowing
4136 ahead is the most useful thing to do. Also added was a pg_restore
4137 option to give the old behavior of exiting on an error.
4138 </para>
4139 </listitem>
4141 <listitem>
4142 <para>
4143 <application>pg_restore</> <option>-l</> display now includes
4144 objects' schema names
4145 </para>
4146 </listitem>
4148 <listitem>
4149 <para>
4150 New begin/end markers in <application>pg_dump</> text output (Bruce)
4151 </para>
4152 </listitem>
4154 <listitem>
4155 <para>
4156 Add start/stop times for
4157 <application>pg_dump</>/<application>pg_dumpall</> in verbose mode
4158 (Bruce)
4159 </para>
4160 </listitem>
4162 <listitem>
4163 <para>
4164 Allow most <application>pg_dump</> options in
4165 <application>pg_dumpall</> (Christopher)
4166 </para>
4167 </listitem>
4169 <listitem>
4170 <para>
4171 Have <application>pg_dump</> use <command>ALTER OWNER</> rather
4172 than <command>SET SESSION AUTHORIZATION</> by default
4173 (Christopher)
4174 </para>
4175 </listitem>
4177 </itemizedlist>
4178 </sect3>
4181 <sect3>
4182 <title>libpq Changes</title>
4183 <itemizedlist>
4185 <listitem>
4186 <para>
4187 Make libpq's <option>SIGPIPE</> handling thread-safe (Bruce)
4188 </para>
4189 </listitem>
4191 <listitem>
4192 <para>
4193 Add <function>PQmbdsplen()</> which returns the display length
4194 of a character (Tatsuo)
4195 </para>
4196 </listitem>
4198 <listitem>
4199 <para>
4200 Add thread locking to <application>SSL</> and
4201 <application>Kerberos</> connections (Manfred Spraul)
4202 </para>
4203 </listitem>
4205 <listitem>
4206 <para>
4207 Allow <function>PQoidValue()</>, <function>PQcmdTuples()</>, and
4208 <function>PQoidStatus()</> to work on <command>EXECUTE</command>
4209 commands (Neil)
4210 </para>
4211 </listitem>
4213 <listitem>
4214 <para>
4215 Add <function>PQserverVersion()</> to provide more convenient
4216 access to the server version number (Greg Sabino Mullane)
4217 </para>
4218 </listitem>
4220 <listitem>
4221 <para>
4222 Add <function>PQprepare/PQsendPrepared()</> functions to support
4223 preparing statements without necessarily specifying the data types
4224 of their parameters (Abhijit Menon-Sen)
4225 </para>
4226 </listitem>
4228 <listitem>
4229 <para>
4230 Many ECPG improvements, including <command>SET DESCRIPTOR</> (Michael)
4231 </para>
4232 </listitem>
4234 </itemizedlist>
4235 </sect3>
4238 <sect3>
4239 <title>Source Code Changes</title>
4240 <itemizedlist>
4242 <listitem>
4243 <para>
4244 Allow the database server to run natively on Windows (Claudio, Magnus, Andrew)
4245 </para>
4246 </listitem>
4248 <listitem>
4249 <para>
4250 Shell script commands converted to C versions for Windows support (Andrew)
4251 </para>
4252 </listitem>
4254 <listitem>
4255 <para>
4256 Create an extension makefile framework (Fabien Coelho, Peter)
4257 </para>
4258 <para>
4259 This simplifies the task of building extensions outside the original
4260 source tree.
4261 </para>
4262 </listitem>
4264 <listitem>
4265 <para>
4266 Support relocatable installations (Bruce)
4267 </para>
4268 <para>
4269 Directory paths for installed files (such as the
4270 <filename>/share</> directory) are now computed relative to the
4271 actual location of the executables, so that an installation tree
4272 can be moved to another place without reconfiguring and
4273 rebuilding.
4274 </para>
4275 </listitem>
4277 <listitem>
4278 <para>
4279 Use <option>--with-docdir</> to choose installation location of documentation; also
4280 allow <option>--infodir</> (Peter)
4281 </para>
4282 </listitem>
4284 <listitem>
4285 <para>
4286 Add <option>--without-docdir</> to prevent installation of documentation (Peter)
4287 </para>
4288 </listitem>
4290 <listitem>
4291 <para>
4292 Upgrade to <application>DocBook</> V4.2 SGML (Peter)
4293 </para>
4294 </listitem>
4296 <listitem>
4297 <para>
4298 New <literal>PostgreSQL</> <application>CVS</> tag (Marc)
4299 </para>
4300 <para>
4301 This was done to make it easier for organizations to manage their
4302 own copies of the <productname>PostgreSQL</productname>
4303 <application>CVS</> repository. File version stamps from the master
4304 repository will not get munged by checking into or out of a copied
4305 repository.
4306 </para>
4307 </listitem>
4309 <listitem>
4310 <para>
4311 Clarify locking code (Manfred Koizar)
4312 </para>
4313 </listitem>
4315 <listitem>
4316 <para>
4317 Buffer manager cleanup (Neil)
4318 </para>
4319 </listitem>
4321 <listitem>
4322 <para>
4323 Decouple platform tests from CPU spinlock code (Bruce, Tom)
4324 </para>
4325 </listitem>
4327 <listitem>
4328 <para>
4329 Add inlined test-and-set code on PA-RISC for <application>gcc</>
4330 (ViSolve, Tom)
4331 </para>
4332 </listitem>
4334 <listitem>
4335 <para>
4336 Improve i386 spinlock code (Manfred Spraul)
4337 </para>
4338 </listitem>
4340 <listitem>
4341 <para>
4342 Clean up spinlock assembly code to avoid warnings from newer
4343 <application>gcc</> releases (Tom)
4344 </para>
4345 </listitem>
4347 <listitem>
4348 <para>
4349 Remove JDBC from source tree; now a separate project
4350 </para>
4351 </listitem>
4353 <listitem>
4354 <para>
4355 Remove the libpgtcl client interface; now a separate project
4356 </para>
4357 </listitem>
4359 <listitem>
4360 <para>
4361 More accurately estimate memory and file descriptor usage (Tom)
4362 </para>
4363 </listitem>
4365 <listitem>
4366 <para>
4367 Improvements to the Mac OS X startup scripts (Ray A.)
4368 </para>
4369 </listitem>
4371 <listitem>
4372 <para>
4373 New <function>fsync()</> test program (Bruce)
4374 </para>
4375 </listitem>
4377 <listitem>
4378 <para>
4379 Major documentation improvements (Neil, Peter)
4380 </para>
4381 </listitem>
4383 <listitem>
4384 <para>
4385 Remove <application>pg_encoding</application>; not needed
4386 anymore
4387 </para>
4388 </listitem>
4390 <listitem>
4391 <para>
4392 Remove <application>pg_id</application>; not needed anymore
4393 </para>
4394 </listitem>
4396 <listitem>
4397 <para>
4398 Remove <application>initlocation</application>; not needed
4399 anymore
4400 </para>
4401 </listitem>
4403 <listitem>
4404 <para>
4405 Auto-detect thread flags (no more manual testing) (Bruce)
4406 </para>
4407 </listitem>
4409 <listitem>
4410 <para>
4411 Use Olson's public domain <application>timezone</> library (Magnus)
4412 </para>
4413 </listitem>
4415 <listitem>
4416 <para>
4417 With threading enabled, use thread flags on Unixware for
4418 backend executables too (Bruce)
4419 </para>
4420 <para>
4421 Unixware cannot mix threaded and nonthreaded object files in the
4422 same executable, so everything must be compiled as threaded.
4423 </para>
4424 </listitem>
4426 <listitem>
4427 <para>
4428 <application>psql</> now uses a <application>flex</>-generated
4429 lexical analyzer to process command strings
4430 </para>
4431 </listitem>
4433 <listitem>
4434 <para>
4435 Reimplement the linked list data structure used throughout the
4436 backend (Neil)
4437 </para>
4438 <para>
4439 This improves performance by allowing list append and length
4440 operations to be more efficient.
4441 </para>
4442 </listitem>
4444 <listitem>
4445 <para>
4446 Allow dynamically loaded modules to create their own server configuration
4447 parameters (Thomas Hallgren)
4448 </para>
4449 </listitem>
4451 <listitem>
4452 <para>
4453 New Brazilian version of FAQ (Euler Taveira de Oliveira)
4454 </para>
4455 </listitem>
4457 <listitem>
4458 <para>
4459 Add French FAQ (Guillaume Lelarge)
4460 </para>
4461 </listitem>
4463 <listitem>
4464 <para>
4465 New <application>pgevent</> for Windows logging
4466 </para>
4467 </listitem>
4469 <listitem>
4470 <para>
4471 Make libpq and ECPG build as proper shared libraries on OS X (Tom)
4472 </para>
4473 </listitem>
4475 </itemizedlist>
4476 </sect3>
4479 <sect3>
4480 <title>Contrib Changes</title>
4481 <itemizedlist>
4483 <listitem>
4484 <para>
4485 Overhaul of <filename>contrib/dblink</> (Joe)
4486 </para>
4487 </listitem>
4489 <listitem>
4490 <para>
4491 <filename>contrib/dbmirror</> improvements (Steven Singer)
4492 </para>
4493 </listitem>
4495 <listitem>
4496 <para>
4497 New <filename>contrib/xml2</> (John Gray, Torchbox)
4498 </para>
4499 </listitem>
4501 <listitem>
4502 <para>
4503 Updated <filename>contrib/mysql</filename>
4504 </para>
4505 </listitem>
4507 <listitem>
4508 <para>
4509 New version of <filename>contrib/btree_gist</> (Teodor)
4510 </para>
4511 </listitem>
4513 <listitem>
4514 <para>
4515 New <filename>contrib/trgm</>, trigram matching for
4516 <productname>PostgreSQL</productname> (Teodor)
4517 </para>
4518 </listitem>
4520 <listitem>
4521 <para>
4522 Many <filename>contrib/tsearch2</> improvements (Teodor)
4523 </para>
4524 </listitem>
4526 <listitem>
4527 <para>
4528 Add double metaphone to <filename>contrib/fuzzystrmatch</> (Andrew)
4529 </para>
4530 </listitem>
4532 <listitem>
4533 <para>
4534 Allow <filename>contrib/pg_autovacuum</> to run as a Windows service (Dave Page)
4535 </para>
4536 </listitem>
4538 <listitem>
4539 <para>
4540 Add functions to <filename>contrib/dbsize</> (Andreas Pflug)
4541 </para>
4542 </listitem>
4544 <listitem>
4545 <para>
4546 Removed <filename>contrib/pg_logger</>: obsoleted by integrated logging
4547 subprocess
4548 </para>
4549 </listitem>
4551 <listitem>
4552 <para>
4553 Removed <filename>contrib/rserv</>: obsoleted by various separate projects
4554 </para>
4555 </listitem>
4557 </itemizedlist>
4558 </sect3>
4560 </sect2>
4561 </sect1>