Accueil / Blog / Métier / Archives / What you don't know about PostgreSQL 8.3

What you don't know about PostgreSQL 8.3

Par Régis Leroy — publié 30/10/2008
With the new PostgreSQL server versions in place (8.2 and 8.3) and in a more general way in the 8.x series, some nice fonctionalities have been added. Let's have a short look at the most interesting ones.
What you don't know about PostgreSQL 8.3

FILLFACTOR=50 in CREATE TABLE instructions (since 8.2)

FILLFACTOR is 100% by default and is a good default setting for tables where the basic usage is INSERTS (and select). But when you know that you'll make a lot of UPDATEs on your rows you should decrease this factor. This way some space on the table will be reserved near your inserted rows. This space will then be used as a work zone when you'll make an UPDATE on the row. And the magic effect is that this work zone won't be at the end of the table but near your row, in the same page in memory. see postgreSQL documentation page for details.

Returning on INSERT INTO to get your inserted Id (since 8.2)

The classical way to get you 'last insert Id' in PostgreSQl as always been using currval(SEQUENCE) This is right and secure as PRIMARY KEYS ar usually defined as SEQUENCEs with DEFAULT nextval(SEQUENCE). And currvall render the last value set by nextval in the current session (others concurrent sessions cannot interfere with it).
But that's not something easy to understand for newbies and very bad example with max(id) can always be found googling around. Now you can add a RETURNING MyId code on your INSERT query and the result of your insert won't be the row OID anymore but your Id (or anything else if you want).

Consult postgreSQL documentation page for details.

TOAST fields

TOAST means 'The Oversized-Attribute Storage Technique'.

You can set up to 1Gb in one field of your row. This column won't be saved in the same physical file as the others. Another file will be created to store such big fields. postgreSQL documentation page is still the best reference.
If you wonder about the size of your tables and the physical files on your filesystem you should not. Your tables are always split in files of 2Gb. And Toast values are stored on their own files.

Table inheritance

You can define a table B as child of table A. Request on table A will then render rows from A and B tables. With ONLY keyword you can limit requests on A with A rows. A could have several tables (B, C, D, etc). Indexes are done tables by table, and are by this way shorter.

This is quite powerfull but you'll have some problems with contraints. UNIQUE constraints for example are done for each table. You cannot ensure A+B+C+D rows will not share the same value for this 'UNIQUE' constraint. Setting Referential intergrity from one of this table to a Z table is easy (but should be done for each table). But setting the reverse relation from Z to A+B+C+D isn't possible.

You should really look postgreSQL documentation page, as always.

Table partitionning

One of the most powerfull thing you can do with INHERITANCE is table PARTITIONNING. Using TABLESPACEs you can define several different physical storage locations for your databases.

TABLESPACES can easily be used for a database, a table, or even for an index (or the WAL sync log). This is fine. You can use several storage devices with different characteristics, each adapted to your differents needs (capacity, speed, sync/async, etc).

But this combined with INHERITANCE becomes even more powerfull: Define table A as an empty table. Define table B and C as child tables of A, and use different tablespaces for B and C. You then have a virtual A table with his content spread on diferent storage devices (or not, you could use the TABLESPACE on the same storage but you'll lose most of the power of the 'thing').

Your benefits? smaller indexes, on different devices, which can run in parallel, some problems with constraints as with point 4), but this is not a problem for all tables, and for a huge table this TABLESPACE splitting could be a coll thing to study. Have a look at postgreSQL documentation page.

One last point, you'll have to defined how the rows are splitted with the different tables (ranges, or domains, or anything else), you'll maybe have to check RULES as well, even with simple INHERITANCE , because INSERT for example should be done on the child table, and INSERT on the main TABLE should be redirected elsewhere.

Notify / Listen

PostgreSQL has a builtin fonctionnality for Observer/observable Design Pattern. You can NOTIFY something, as an SQL command and at the end of your transaction (or directly if you're not in a transaction) others SQL sessions which have registered this notification with LISTEN will get your notification (the doc). Usefull with server processes (while true processes), a cli process in PHp for example with builtin pg lib but not with PDO actually. Here is as well a Java example and examples in python, the demo2a/b files.

Follow me also on

Voir aussi
Formation PostgreSQL / PostGIS du 27 au 29 septembre à Paris Formation PostgreSQL / PostGIS du 27 au 29 septembre à Paris 06/07/2016

Découvrez les outils Libres pour gérer vos données spatiales.

Nouvelle formation base de données PostgreSQL Nouvelle formation base de données PostgreSQL 10/12/2015

Découvrez notre plan de formation PostgreSQL disponible sur Toulouse, Nantes et Paris.

Dessiner une ville à la main avec TileMill (3 – Occupation des sols et cours d'eau) Dessiner une ville à la main avec TileMill (3 – Occupation des sols et cours d'eau) 20/03/2014

Nous avons vu comment représenter les bâtiments. Je m'intéresse maintenant à la mise en forme ...

Dessiner une ville à la main avec TileMill (2 - Découper 340 000 polygones) Dessiner une ville à la main avec TileMill (2 - Découper 340 000 polygones) 19/03/2014

Comme nous l'avons vu dans un précédent article, la création d'une carte urbaine reproduisant un ...

Dessiner une ville à la main avec TileMill (1 - Les bâtiments) Dessiner une ville à la main avec TileMill (1 - Les bâtiments) 14/03/2014

L'objectif de ce projet est d'afficher une carte dans un style crayonné à partir de données ...