1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
|
<!-- $PostgreSQL: pgsql/doc/src/sgml/release-8.5.sgml,v 1.9 2009/12/11 01:33:35 adunstan Exp $ -->
<sect1 id="release-8-5">
<title>Release 8.5alpha2</title>
<sect2>
<title>Overview</title>
<para>
PostgreSQL alpha releases are snapshots of development code. They
are intended to preview and test upcoming features and to provide
the possibility for early feedback. They should not be used in
production installations or active development projects. While the
PostgreSQL code is continuously subject to a number of automated
and manual tests, alpha releases might have serious bugs. Also
features may be changed incompatibly or removed at any time during
the development cycle.
</para>
<para>
The development cycle of a PostgreSQL major release alternates
between periods of development and periods of integration work,
called commit fests, normally one month each. Alpha releases are
planned to be produced at the end of every commit fest, thus every
two months. Since the first commit fest starts within a month from
the beginning of development altogether, early alpha releases are
not indicative of the likely feature set of the final release.
</para>
<para>
The release notes below highlight user visible changes and new
features. There are normally numerous bug fixes and performance
improvements in every new snapshot of PostgreSQL, and it would be
too bulky to attempt to list them all. Note that many bug fixes are
also backported to stable releases of PostgreSQL, and you should be
using those if you are looking for bug-fix-only upgrades for your
current installations.
</para>
<para>
The release notes are cumulative over all alpha releases. Items
that are new in the latest alpha release
are <emphasis>emphasized</emphasis>.
</para>
</sect2>
<sect2>
<title>Migration</title>
<para>
To upgrade from any release to an alpha release or from an alpha
release to any other release will most likely require a
dump/restore upgrade procedure. It may happen that this is not
necessary in particular cases, but that is not verified beforehand.
(The server will warn you in any case when a dump/restore is
necessary if you attempt to use it with an old data directory.)
Note, however, that the dump/restore upgrade procedure is expected
to work for alpha releases, and problems in this area should be
reported.
</para>
</sect2>
<sect2>
<title>Testing</title>
<para>
The primary reason we release alphas is to get users to test new
features as early as possible. If you are interested in helping
with organized testing, please see
<ulink url="http://wiki.postgresql.org/wiki/HowToBetaTest">the
testing information page</ulink>.
</para>
</sect2>
<sect2>
<title>Changes</title>
<sect3>
<title>SQL Features</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Add SQL-compliant triggers on columns, which fire only if
certain columns are named in the UPDATE's SET list.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Add CREATE LIKE INCLUDING COMMENTS and STORAGE, and INCLUDING
ALL shortcut to allow users to make an exact copy of a table including
all options and features.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Define a new, more extensible syntax for COPY options
in order to support additional COPY options in the future.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Modify the definition of window-function PARTITION
BY and ORDER BY clauses so that their elements are always
taken as simple expressions over the query's input
columns. This fixes a bug.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Fix bug with nested WITH RECURSIVE statements.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Add surrogate pair support for U& string and identifier
syntax.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Add Unicode escapes in E'...' strings.</>
</para>
</listitem>
<listitem>
<para>
DROP COLUMN and DROP CONSTRAINT now support an IF EXISTS clause so
that users can avoid fatal errors when running repeatable scripts.
</para>
</listitem>
<listitem>
<para>
UNIQUE constraints can now be DEFERRABLE. This is primarily useful
for incremental updates of numerical keys, e.g. "ID = ID +
1"
</para>
</listitem>
<listitem>
<para>
Allow parentheses around the query expression that follows a WITH
clause.
</para>
</listitem>
<listitem>
<para>
INFORMATION_SCHEMA, a catalog of standard views of database
objects, has been updated to the SQL:2008 standard.
</para>
</listitem>
<listitem>
<para>
Change character_octet_length to more sensible values in
INFORMATION_SCHEMA.
</para>
</listitem>
<listitem>
<para>
Allow * as parameter for FORCE QUOTE for COPY CSV, so that all
columns will be quoted.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Performance</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Make TRUNCATE do truncate-in-place when processing
a relation that was created or previously truncated in the
current (sub)transaction.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Implement "join removal" for cases where the inner side
of a left join is unique and is not referenced above the join. This should
speed up many ORM-generated and reporting tool queries.</emphasis>
</para>
</listitem>
<listitem>
<para>
<emphasis>Remove the use of the flat files pg_auth and
pg_database in order to improve performance. (Warning: pgbouncer
and possibly other tools currently suggest referring to the pg_auth
file for its user database. Such schemes will no longer work.)</emphasis>
</para>
</listitem>
<listitem>
<para>
EXPLAIN allows output of plans in XML, JSON, or YAML format for automated
processing of explain plans by analysis or visualization tools.
</para>
</listitem>
<listitem>
<para>
EXPLAIN now supports the use of generic options in EXPLAIN ( option
value, ... ) format, which permits the creation of additional
EXPLAIN options.
</para>
</listitem>
<listitem>
<para>
ALTER TABLE ... ALTER COLUMN ... SET STATISTICS DISTINCT allows
users to manually tweak the number of distinct values estimated for
a column, to fix cases where ANALYZE estimates are incorrect.
</para>
</listitem>
<listitem>
<para>
Make GEQO's planning deterministic by having it start from a
predictable random number seed each time.
</para>
</listitem>
<listitem>
<para>
Rewrite GEQO's gimme_tree function so that it always finds a legal
join sequence. Previously, it could have failed to produce a plan
in some cases.
</para>
</listitem>
<listitem>
<para>
Tweak TOAST code so that columns marked with MAIN storage strategy
are not forced out-of-line unless that is necessary to make the row
fit on a page. Previously, they were forced out-of-line if needed
to get the row down to the default target size (1/4th page).
</para>
</listitem>
<listitem>
<para>
Simplify the forms foo <> true and foo <> false to foo
= false and foo = true during query optimization.
</para>
</listitem>
<listitem>
<para>
Avoid per-send() system calls to manage SIGPIPE in libpq, if the
platform provides either sockopt(SO_NOSIGPIPE) or the MSG_NOSIGNAL
flag to send().
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Administration and Monitoring</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Add a Boolean server configuration parameter
"bonjour" to control whether a Bonjour-enabled
build actually attempts to advertise itself via Bonjour.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>When reloading postgresql.conf, log what parameters actually
changed.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Make it possibly to specify server configuration parameters
per user-database combination. Add a \drds command to psql to
display the settings.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Allow the collection of statistics on sequences.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Increase the maximum value of extra_float_digits to
3, and have pg_dump use that value when the backend is new
enough to allow it, because it is possible to need 3 extra
digits for float4 values (but not for float8 values).</>
</para>
</listitem>
<listitem>
<para>
Add the ability to include the SQLSTATE error code of any error
messages in the PostgreSQL activity log with the new
log_line_prefix placeholder %e.
</para>
</listitem>
<listitem>
<para>
Show the exact value being complained of in
unique-constraint-violation error messages, including unique-index
build failures.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Security</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Add ALTER DEFAULT PRIVILEGES command, which allows
users to adjust the privileges that will be applied to
subsequently-created objects.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Add GRANT/REVOKE ON ALL TABLES/SEQUENCES/FUNCTIONS IN SCHEMA.
This makes it easier to manage permissions on database objects.</emphasis>
</para>
</listitem>
<listitem>
<para>
<emphasis>Support "samehost" and "samenet" specifications
in pg_hba.conf. This allows users with dynamic server addresses to run
PostgreSQL without frequently modifying pg_hba.conf</emphasis>
</para>
</listitem>
<listitem>
<para>
New has_sequence_privilege() functions allow you to check sequence
privileges for a given ROLE.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Built-In Functions</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Support POSIX-compatible interpretation of ? as well as {m,n}
and related constructs in SIMILAR TO, per SQL:2008.</>
</para>
</listitem>
<listitem>
<para>
The to_char() formatting functions now supports EEEE (scientific
notation).
</para>
</listitem>
<listitem>
<para>
Use floor() not rint() when reducing precision of fractional
seconds in timestamp_trunc, timestamptz_trunc, and interval_trunc()
for the float-datetime case. This improves accuracy of time
calculations.
</para>
</listitem>
<listitem>
<para>
Fix ancient bug in handling of to_char() modifier 'TH', when used
with HH.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Data Types</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Fix encoding handling in binary input function of xml type.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Tighten binary receive functions so that they reject values
that the text input functions don't accept either.</>
</para>
</listitem>
<listitem>
<para>
New hex-string input and output format options for type bytea. Hex
output format is enabled by default, which is an incompatible
change. See the new bytea_output parameter if you need to restore
compatibility.
</para>
</listitem>
<listitem>
<para>
Adds prefix support for text search synonym dictionary, allowing
creation of synonyms on partial matches.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Server Tools</title>
<itemizedlist>
<listitem>
<para>
<emphasis>It is now reasonably safe to use pg_ctl to start
the postmaster from a boot-time script.</emphasis>
</para>
</listitem>
<listitem>
<para>
pg_dump/pg_restore --clean now drops large objects.
</para>
</listitem>
<listitem>
<para>
Modify parallel pg_restore ordering logic to avoid a potential
O(N^2) slowdown for some complex databases.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>psql</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Implement significantly saner behavior when two or
more psql sessions overlap in their use of the history file.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Add "pset linestyle ascii/unicode" option to psql,
allowing our traditional ASCII-art style of table output to
be upgraded to use Unicode box drawing characters if
desired.</>
</para>
</listitem>
<listitem>
<para>
Have \d show child tables that inherit from the specified parent
</para>
</listitem>
<listitem>
<para>
psql now shows the index methods in \di
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Procedural Languages</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Add DO statement to support execution of procedural language
code without having to create a function for it.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Support use of function argument names to identify which
actual arguments match which function parameters. The syntax
uses AS, for example funcname(value AS arg1, anothervalue AS
arg2).</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Fix/improve bytea and boolean support in PL/Python. Data type
conversion into and out of PL/Python previously went through
an intermediate string representation, which caused various
discrepancies especially with bytea and boolean data. This is
now fixed by converting the values directly.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>PL/Python now accepts Unicode objects where it previously
only accepted string objects (for example, as return
value). Unicode objects are converted to the PostgreSQL
server encoding as necessary.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Improve error context reporting in PL/Perl, for
easier debugging.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>PL/pgSQL IN parameters now accept value assignments.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Convert a Perl array to a PostgreSQL array when returned by
set-returning functions as well as non-SRFs.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Allow cursor commands MOVE FORWARD n, MOVE BACKWARD n,
MOVE FORWARD ALL, MOVE BACKWARD ALL in PL/pgSQL.</>
</para>
</listitem>
<listitem>
<para>
PL/pgSQL functions can now better cope with row types
containing dropped columns.
</para>
</listitem>
<listitem>
<para>
Improve error context reporting in PL/Python, for easier
debugging.
</para>
</listitem>
<listitem>
<para>
Greatly expand the regression testing for PL/Python.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Additional Supplied Modules</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Multiple improvements in contrib/hstore, including
raising limits on keys and values, conversions to and from
records and arrays, and support for GROUP BY and DISTINCT.</emphasis>
</para>
</listitem>
<listitem>
<para>
pgbench is now multi-threaded, allowing it to use multiple CPU's
for its client connections, and to do more realistic workload
testing.
</para>
</listitem>
<listitem>
<para>
Added the ability to retrieve asynchronous notifications using
dblink, via the addition of the function dblink_get_notify().
</para>
</listitem>
<listitem>
<para>
Added matchorig, matchsynonyms, and keepsynonyms options to
contrib/dict_xsyn.
</para>
</listitem>
<listitem>
<para>
Added contrib/unaccent.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Development</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Add ECPG function that returns the current transaction status.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Make ECPG more robust against applications freeing strings.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Make libpq reject non-numeric and out-of-range port numbers with a
suitable error message.</emphasis>
</para>
</listitem>
<listitem>
<para>
Functions which conflict with C++ reserved words have been renamed,
making backend header files now safe to use with C++ libraries.
</para>
</listitem>
<listitem>
<para>
Add man pages for SPI functions.
</para>
</listitem>
<listitem>
<para>
ECPG now includes a STRING datatype for Informix compatibility
mode.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Ports</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Change the WIN32 API version to be 5.01 (Windows XP), to
bring in the proper IPv6 headers in newer SDKs.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Write to the Windows eventlog in UTF-16, converting the
message encoding as necessary.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Replace use of the long-deprecated Bonjour API
DNSServiceRegistrationCreate with the not-so-deprecated
DNSServiceRegister. The new code will fail on Mac OS X
releases before 10.3.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Install a hopefully-temporary workaround for Mac OS X Snow Leopard
readdir() bug.</>
</para>
</listitem>
<listitem>
<para>
Reserve the shared memory region during backend startup on Windows,
so that memory allocated by starting third party DLLs doesn't end
up conflicting with it. Hopefully this solves the long-time issue
with "could not reattach to shared memory" errors on
Win32.
</para>
</listitem>
<listitem>
<para>
Add s_lock support for SuperH architecture (not well tested).
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3>
<title>Source code, build options</title>
<itemizedlist>
<listitem>
<para>
<emphasis>Fix inclusions of readline/editline header files so that we
only attempt to #include the version of history.h that is in
the same directory as the readline.h we are using. This
avoids problems in some scenarios where both readline and
editline are installed.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Derived files that are shipped in the distribution used to be
built in the source directory even for out-of-tree
builds. They are now also built in the build tree. This
should be more convenient for certain developers' workflows.</>
</para>
</listitem>
<listitem>
<para>
<emphasis>Translations were updated.</>
</para>
</listitem>
<listitem>
<para>
Upgrade to Autoconf 2.63 (not relevant to users of distribution
tarballs).
</para>
</listitem>
<listitem>
<para>
Minimum version of Flex is now 2.5.31, to support reentrant
scanners (not relevant to users of distribution tarballs).
</para>
</listitem>
<listitem>
<para>
Documentation build rules have been improved. The generated
documentation files are now shipped "loose", not in
sub-tarballs.
</para>
</listitem>
<listitem>
<para>
New toolchain to generate man pages. From now on, the man pages
will be current in every release.
</para>
</listitem>
<listitem>
<para>
Code-coverage testing support now extends to the entire source
tree, not only src/backend/.
</para>
</listitem>
<listitem>
<para>
Make the core scanner re-entrant, along with additional fixes that
will let it be used directly by PL/pgSQL.
</para>
</listitem>
</itemizedlist>
</sect3>
</sect2>
</sect1>
|