PostgreSQL 9.3.25 Documentation | ||||
---|---|---|---|---|
Prev | Up | Chapter 31. libpq - C Library | Next |
PostgreSQL offers asynchronous notification via the LISTEN and NOTIFY commands. A client session registers its interest in a particular notification channel with the LISTEN command (and can stop listening with the UNLISTEN command). All sessions listening on a particular channel will be notified asynchronously when a NOTIFY command with that channel name is executed by any session. A "payload" string can be passed to communicate additional data to the listeners.
libpq applications submit
LISTEN, UNLISTEN,
and NOTIFY commands as ordinary SQL
commands. The arrival of NOTIFY messages
can subsequently be detected by calling PQnotifies
.
The function PQnotifies
returns
the next notification from a list of unhandled notification
messages received from the server. It returns a null pointer if
there are no pending notifications. Once a notification is returned
from PQnotifies
, it is considered
handled and will be removed from the list of notifications.
PGnotify *PQnotifies(PGconn *conn); typedef struct pgNotify { char *relname; /* notification channel name */ int be_pid; /* process ID of notifying server process */ char *extra; /* notification payload string */ } PGnotify;
After processing a PGnotify object
returned by PQnotifies
, be sure to
free it with PQfreemem
. It is
sufficient to free the PGnotify
pointer; the relname and extra fields do not represent separate
allocations. (The names of these fields are historical; in
particular, channel names need not have anything to do with
relation names.)
Example 31-2 gives a sample program that illustrates the use of asynchronous notification.
PQnotifies
does not actually read
data from the server; it just returns messages previously absorbed
by another libpq function. In
prior releases of libpq, the only
way to ensure timely receipt of NOTIFY
messages was to constantly submit commands, even empty ones, and
then check PQnotifies
after each
PQexec
. While this still works, it is
deprecated as a waste of processing power.
A better way to check for NOTIFY
messages when you have no useful commands to execute is to call
PQconsumeInput
, then check
PQnotifies
. You can use select()
to wait for data to arrive from the
server, thereby using no CPU
power unless there is something to do. (See PQsocket
to obtain the file descriptor number to
use with select()
.) Note that this
will work OK whether you submit commands with PQsendQuery
/PQgetResult
or simply use PQexec
. You should, however, remember to check
PQnotifies
after each PQgetResult
or PQexec
, to see if any notifications came in
during the processing of the command.