Nouvelles hebdomadaires de PostgreSQL - 8 avril 2007
Maintenant que les fonctionnalités sont gelées, les révisions sont débattues.
Félicitations à Tom Dunstan pour le nouveau type enum.
Les nouveautés des produits dérivés
PostgreSQL Local
PgDay, c'est par ici !
http://www.pgday.it/en/node/95
Les souscriptions sont ouvertes pour PGCon 2007 :
http://www.pgcon.org/2007/registration.php
PostgreSQL dans les média
PostgreSQL Weekly News vous est présenté cette semaine par David Fetter.
Adaptation francophone de Stéphane Schildknecht, Guillaume de Rorthais, Cédric Villemain.
Correctifs appliqués
Neil Conway a commité :
-
la correction de quelques typos dans les docs.
Tatsuo Ishii a commité :
-
l'ajout de l'option -F pour positionner le facteur de remplissage des "tellers", comptes et branches. Pavan Deolasee a contribué au correctif. Modifications de la doc japonaise par by Tatsuo Ishii ;
-
le correctif de Greg Smith qui ajoute une option -l pour ajouter les timestamp à pgbench. Mise à jour de la doc japonaise par Tasuo Ishii ;
-
le correctif de ITAGAKI Takahiro qui améliore pgbench de différentes façons.
Andrew Dunstan a commité :
-
dans pgsql/src/tools/msvc/vcregress.bat, la vérification de contrib n'est effectuée que s'il existe un Makefile ;
-
dans pgsql/src/tools/msvc/vcregress.bat, l'amélioration des en-têtes de test ;
-
dans pgsql/src/tools/msvc/Install.pm, les fichiers pour xml2 ne sont pas installés si la construction ne prend pas la libxml ;
-
la vérification des longueurs de libellés d'enum dans leur définition et lors de la saisie pour s'assurer qu'ils entrent un champ nom et ne causeront pas d'erreur syscache.
Bruce Momjian a commité :
-
le marquage de TODO comme fait : "-Make CLUSTER preserve recently-dead tuples per MVCC requirements."
-
le marquage de TODO comme fait : "Add more logical syntax CLUSTER table USING index"
-
le correctif de Holger Schurig qui ajoute le support de la syntaxe "CLUSTER table USING index", plus logique qua la version précédente ;
-
le correctif de Greg Smith qui ajoute les statistiques d'utilisation aux informations disponibles dans contrib/pgbuffercache ;
-
de menues améliorations dans la documentation de REVOKE ;
-
la suppression de la syntaxe en standard SQL de GRANT/REVOKE --- source de confusion ;
-
le correctif de Mark Fuhr concernant l'écriture du mot "symmetric." Rétro-correctif de PG8.2 - Le TODO : "Allow use of indexes to search for NULLs." est marqué fait ;
-
le TODO : "Support a smaller header for short variable-length fields." est marqué fait - la corrections de quelques commentaires désormais obsolètes concernant l'espace utilisé par certains tyes de données ;
-
la mise à jour du message d'erreur XML si la libxml manque ; la mise à jour de la sortie des tests de régression pour refléter cette modification ;
-
l'ajout d'une URL au TODO : "Reduce WAL traffic so only modified values are written rather than entire rows."
-
l'amélioration de la documentation/du message d'avertissement lorsque --with-libxml n'est pas utilisé lors de l'installation ;
-
la restauration de l'item 3.7 de la FAQ perdu dans un commit précédant ;
-
la correctif de Marko Kreen qui supprime le dernier transtypage dans les définitions de structure en PL/PythonU. C'est une mauvaise pratique, puisqu'elle masque les problèmes du compilateur. Le transtypage est une pratique populaire dans certains milieux pour définir des fonctions comme foo(MyObj *) à la place de foo(PyObject *), ce qui évite une variable locale dans une fonction et facilite les appels directs. Puisque PL/PythonU n'utilise pas ce stylen, ces transtypages étaient inutiles, dès le départ ;
-
le correctif de Gregory Stark qui documente la façon d'identifier un index invalide après l'échec de CREATE INDEX CONCURRENTLY ;
-
le marquage du TODO comme fait : "Allow PL/PythonU to return boolean rather than 1/0 ;
-
le correctif de Marko Kreen qui permet à PL/pythonU >= version 2.3 de retourner boolean, plutôt que 1/0 ;
-
le correctif de Marko Kreen qui permet à PL/PythonU de compiler avec Python 2.5. Ces modifications étaient nécessaires du fait de modifications dans l'API de Python ;
-
dans pgsql/src/port/thread.c, la mise à jour du commentaire de la nouvelle licalisation de thread_test ;
-
la mise à jour du TODO : "Add idle_in_transaction_timeout GUC so locks are not held for long periods of time."
-
l'ajout du TODO: "Allow all data types to cast to and from TEXT."
-
l'ajout du TODO: "Add idle_timeout GUC so locks are not held for log periods of time."
-
l'ajout d'une URL au TODO: "Allow UPDATE tab SET ROW (col, ...) = (SELECT...)."
-
l'ajout d'une URL au TODO: "Allow commenting of variables in postgresql.conf to restore them to defaults."
-
l'ajout d'une URL au TODO: "Allow a warm standby system to also allow read-only."
-
l'ajout d'une URL au TODO: "Improve speed with indexes"
-
l'ajout du TODO: "Have timestamp subtraction not call justify_hours()?"
-
l'ajout du TODO: "Allow NOTIFY/LISTEN/UNLISTEN to only take relation names, not schema.relation, because the notify code only honors the relation name. schema.relation will now generate a syntax error."
-
l'ajout du TODO: "Fix to_date()-related functions to issue errors consistently"
-
l'ajout du TODO: "Allow PL/PythonU to return boolean rather than 1/0."
-
l'ajout du TODO: "Consider reducing memory used for shared buffer reference count."
-
l'ajout d'une URL au TODO: "Allow RETURN to return row or record functions."
-
le marquage du TODO comme fait: "Support a data type with specific enumerated values (ENUM)."
-
l'ajout du TODO: "Add PQexecf() that allows complex parameter substitution."
Magnus Hagander a commité :
-
dans pgsql/src/tools/msvc/vcregress.bat, les autres tests de regression des contrib doivent continuer si l'un d'eux échoue et retourner un code d'erreur 1 si un test ou plus a échoué ;
-
dans pgsql/src/tools/msvc/vcregress.bat, s'assure que la liste de tests est vidée avant de récupérer la nouvelle liste de tests. Réalisé par Andrew Dunstan ;
-
dans pgsql/src/tools/msvc/Install.pm, n'installe pas les fichiers pour sslinfo lors d'une compilation sans openssl. Réalisé par Andrew Dunstan.
-
dans pgsql/src/tools/msvc/Install.pm, xcopy ne peut travailler qu'avec des chemins utilisant les slash s'ils sont entre guillemets - nécessaire pour que "vcregress check" marche. Signalé par Dave Page.
Teodor Sigaev a commité :
-
la correction de la mise en cache d'initialisation ratée du parser ou de la configuration, signalé par les gens de peufeu.com. Correction propagée dans 7.4.
Tom Lane a commité :
-
edition mineure de la page de référence de CLUSTER.
-
le corretcif de Heikki Linnakangas pour rendre CLUSTER sûr en MVCC.
-
dans pgsql/doc/src/sgml/ref/truncate.sgml, l'ajout d'une note à propos de TRUNCATE qui n'est pas sûr en MVCC.
-
Don't remove the 'alias' field from flattened rangetable entries; there are some corner cases where this is needed by ruleutils.c for proper display of variables during EXPLAIN ;
-
que la clause 'col IS NULL' soit une condition indexable. Réalisé par Teodor Sigaev, avec quelques modifications imposées par Tom Lane.
-
Now that core functionality is depending on autoconf's AC_C_BIGENDIAN to be right, there seems precious little reason to have a pile of hand-maintained endianness definitions in src/include/port/*.h. Get rid of those, and make the couple of places that used them depend on WORDS_BIGENDIAN instead ;
-
Support varlena fields with single-byte headers and unaligned storage. This commit breaks any code that assumes that the mere act of forming a tuple (without writing it to disk) does not "toast" any fields. While all available regression tests pass, I'm not totally sure that we've fixed every nook and cranny, especially in contrib. Greg Stark with some help from Tom Lane ;
-
Remove the CheckpointStartLock in favor of having backends show whether they are in their commit critical sections via flags in the ProcArray. Checkpoint can watch the ProcArray to determine when it's safe to proceed. This is a considerably better solution to the original problem of race conditions between checkpoint and transaction commit: it speeds up commit, since there's one less lock to fool with, and it prevents the problem of checkpoint being delayed indefinitely when there's a constant flow of commits. Heikki Linnakangas, with some kibitzing from Tom ;
-
Decouple the values of TOAST_TUPLE_THRESHOLD and TOAST_MAX_CHUNK_SIZE. Add the latter to the values checked in pg_control, since it can't be changed without invalidating toast table content. This commit in itself shouldn't change any behavior, but it lays some necessary groundwork for experimentation with these toast-control numbers. Note: while TOAST_TUPLE_THRESHOLD can now be changed without initdb, some thought still needs to be given to needs_toast_table() in toasting.c before unleashing random changes ;
-
Fix check_sql_fn_retval to allow the case where a SQL function declared to return void ends with a SELECT, if that SELECT has a single result that is also of type void. Without this, it's hard to write a void function that calls another void function. Per gripe from Peter Eisentraut. Back-patch as far as 8.0 ;
-
Support enum data types. Along the way, use macros for the values of pg_type.typtype whereever practical. Tom Dunstan, with some kibitzing from Tom Lane.
Peter Eisentraut a commité :
-
Update catversion for new XML mapping functions ;
-
Update SQL conformance for SQL to XML mappings ;
-
Mapping schemas and databases to XML and XML Schema. Refactor and document the remaining mapping code ;
-
In pgsql/src/interfaces/ecpg/preproc/Makefile, complete cleaning.
Correctifs rejetés (à ce jour)
-
Zdenek Kotala's patch to add large file support on grounds of lack of use cases.
Correctifs en attente
-
Greg Smith sent in a patch which puts entries in the log file around some backend events that regularly cause client pauses, most of which are visible only when running with log_min_messages = debug2 ;
-
Simon Riggs sent in another version of his "Deferred Transactions, Transaction Guarantee and COMMIT without waiting" patch ;
-
David Fetter sent in a patch to implement arrays of compound types ;
-
Pavan Deolasee sent in versions 6.3 and 7.0 of his WIP HOT patch ;
-
Marko Kreen sent in two more revisions of his RESET SESSION patch ;
-
Heikki Linnakangas sent in two revisions of a patch intended to fix the mdsync never-ending loop problem mentioned at http://archives.postgresql.org/pgsql-hackers/2007-04/msg00259.php
-
Alvaro Herrera sent in another revision of his autovacuum multiworkers patch ;
-
Simon Riggs sent in a comprehensive Reviewers Guide to Deferred Transactions/Transaction Guarantee, complete with the latest version of the "grouped transactions" patch ;
-
Simon Riggs sent in some changes to warm standby.