Commit 1503333f authored by Tom Lane's avatar Tom Lane

Improve documentation about large-object functions.

Copy-editing for previous patch, plus fixing some longstanding markup
issues and oversights (like not mentioning that failures will set the
PQerrorMessage string).
parent 33a71012
...@@ -5804,17 +5804,18 @@ dynamic_library_path = 'C:\tools\postgresql;H:\my_project\lib;$libdir' ...@@ -5804,17 +5804,18 @@ dynamic_library_path = 'C:\tools\postgresql;H:\my_project\lib;$libdir'
<listitem> <listitem>
<para> <para>
In <productname>PostgreSQL</> releases prior to 9.0, large objects In <productname>PostgreSQL</> releases prior to 9.0, large objects
did not have access privileges and were, in effect, readable and did not have access privileges and were, therefore, always readable
writable by all users. Setting this variable to <literal>on</> and writable by all users. Setting this variable to <literal>on</>
disables the new privilege checks, for compatibility with prior disables the new privilege checks, for compatibility with prior
releases. The default is <literal>off</>. releases. The default is <literal>off</>.
Only superusers can change this setting.
</para> </para>
<para> <para>
Setting this variable does not disable all security checks related to Setting this variable does not disable all security checks related to
large objects &mdash; only those for which the default behavior has large objects &mdash; only those for which the default behavior has
changed in <productname>PostgreSQL</> 9.0. changed in <productname>PostgreSQL</> 9.0.
For example, <literal>lo_import()</literal> and For example, <literal>lo_import()</literal> and
<literal>lo_export()</literal> need superuser privileges independent <literal>lo_export()</literal> need superuser privileges regardless
of this setting. of this setting.
</para> </para>
</listitem> </listitem>
......
...@@ -34,17 +34,26 @@ ...@@ -34,17 +34,26 @@
</indexterm> </indexterm>
<para> <para>
All large objects are placed in a single system table called All large objects are stored in a single system table named <link
<classname>pg_largeobject</classname>. linkend="catalog-pg-largeobject"><structname>pg_largeobject</structname></link>.
Each large object also has an entry in the system table <link
linkend="catalog-pg-largeobject-metadata"><structname>pg_largeobject_metadata</structname></link>.
Large objects can be created, modified, and deleted using a read/write API
that is similar to standard operations on files.
</para>
<para>
<productname>PostgreSQL</productname> also supports a storage system called <productname>PostgreSQL</productname> also supports a storage system called
<quote><acronym>TOAST</acronym></quote> that automatically stores values <link
linkend="storage-toast"><quote><acronym>TOAST</acronym></quote></link>,
which automatically stores values
larger than a single database page into a secondary storage area per table. larger than a single database page into a secondary storage area per table.
This makes the large object facility partially obsolete. One This makes the large object facility partially obsolete. One
remaining advantage of the large object facility is that it allows values remaining advantage of the large object facility is that it allows values
up to 4 TB in size, whereas <acronym>TOAST</acronym>ed fields can be at up to 4 TB in size, whereas <acronym>TOAST</acronym>ed fields can be at
most 1 GB. Also, large objects can be randomly modified using a read/write most 1 GB. Also, reading and updating portions of a large object can be
API that is more efficient than performing such operations using done efficiently, while most operations on a <acronym>TOAST</acronym>ed
<acronym>TOAST</acronym>. field will read or write the whole value as a unit.
</para> </para>
</sect1> </sect1>
...@@ -65,14 +74,14 @@ ...@@ -65,14 +74,14 @@
and a set of access permissions, which can be managed using and a set of access permissions, which can be managed using
<xref linkend="sql-grant"> and <xref linkend="sql-grant"> and
<xref linkend="sql-revoke">. <xref linkend="sql-revoke">.
For compatibility with prior releases, see
<xref linkend="guc-lo-compat-privileges">.
<literal>SELECT</literal> privileges are required to read a large <literal>SELECT</literal> privileges are required to read a large
object, and object, and
<literal>UPDATE</literal> privileges are required to write to or <literal>UPDATE</literal> privileges are required to write or
truncate it. truncate it.
Only the large object owner (or the database superuser) can unlink, comment Only the large object's owner (or a database superuser) can delete,
on, or change the owner of a large object. comment on, or change the owner of a large object.
To adjust this behavior for compatibility with prior releases, see the
<xref linkend="guc-lo-compat-privileges"> run-time parameter.
</para> </para>
</sect1> </sect1>
...@@ -81,20 +90,31 @@ ...@@ -81,20 +90,31 @@
<para> <para>
This section describes the facilities that This section describes the facilities that
<productname>PostgreSQL</productname> client interface libraries <productname>PostgreSQL</productname>'s <application>libpq</>
provide for accessing large objects. All large object client interface library provides for accessing large objects.
manipulation using these functions <emphasis>must</emphasis> take The <productname>PostgreSQL</productname> large object interface is
place within an SQL transaction block. modeled after the <acronym>Unix</acronym> file-system interface, with
The <productname>PostgreSQL</productname> large object interface is modeled after analogues of <function>open</function>, <function>read</function>,
the <acronym>Unix</acronym> file-system interface, with analogues of
<function>open</function>, <function>read</function>,
<function>write</function>, <function>write</function>,
<function>lseek</function>, etc. <function>lseek</function>, etc.
</para> </para>
<para> <para>
Client applications which use the large object interface in All large object manipulation using these functions
<application>libpq</application> should include the header file <emphasis>must</emphasis> take place within an SQL transaction block,
since large object file descriptors are only valid for the duration of
a transaction.
</para>
<para>
If an error occurs while executing any one of these functions, the
function will return an otherwise-impossible value, typically 0 or -1.
A message describing the error is stored in the connection object and
can be retrieved with <function>PQerrorMessage</>.
</para>
<para>
Client applications that use these functions should include the header file
<filename>libpq/libpq-fs.h</filename> and link with the <filename>libpq/libpq-fs.h</filename> and link with the
<application>libpq</application> library. <application>libpq</application> library.
</para> </para>
...@@ -103,11 +123,11 @@ ...@@ -103,11 +123,11 @@
<title>Creating a Large Object</title> <title>Creating a Large Object</title>
<para> <para>
<indexterm><primary>lo_creat</></>
The function The function
<synopsis> <synopsis>
Oid lo_creat(PGconn *conn, int mode); Oid lo_creat(PGconn *conn, int mode);
</synopsis> </synopsis>
<indexterm><primary>lo_creat</></>
creates a new large object. creates a new large object.
The return value is the OID that was assigned to the new large object, The return value is the OID that was assigned to the new large object,
or <symbol>InvalidOid</symbol> (zero) on failure. or <symbol>InvalidOid</symbol> (zero) on failure.
...@@ -129,11 +149,11 @@ inv_oid = lo_creat(conn, INV_READ|INV_WRITE); ...@@ -129,11 +149,11 @@ inv_oid = lo_creat(conn, INV_READ|INV_WRITE);
</para> </para>
<para> <para>
<indexterm><primary>lo_create</></>
The function The function
<synopsis> <synopsis>
Oid lo_create(PGconn *conn, Oid lobjId); Oid lo_create(PGconn *conn, Oid lobjId);
</synopsis> </synopsis>
<indexterm><primary>lo_create</></>
also creates a new large object. The OID to be assigned can be also creates a new large object. The OID to be assigned can be
specified by <replaceable class="parameter">lobjId</replaceable>; specified by <replaceable class="parameter">lobjId</replaceable>;
if so, failure occurs if that OID is already in use for some large if so, failure occurs if that OID is already in use for some large
...@@ -162,11 +182,11 @@ inv_oid = lo_create(conn, desired_oid); ...@@ -162,11 +182,11 @@ inv_oid = lo_create(conn, desired_oid);
<title>Importing a Large Object</title> <title>Importing a Large Object</title>
<para> <para>
<indexterm><primary>lo_import</></>
To import an operating system file as a large object, call To import an operating system file as a large object, call
<synopsis> <synopsis>
Oid lo_import(PGconn *conn, const char *filename); Oid lo_import(PGconn *conn, const char *filename);
</synopsis> </synopsis>
<indexterm><primary>lo_import</></>
<replaceable class="parameter">filename</replaceable> <replaceable class="parameter">filename</replaceable>
specifies the operating system name of specifies the operating system name of
the file to be imported as a large object. the file to be imported as a large object.
...@@ -178,11 +198,11 @@ Oid lo_import(PGconn *conn, const char *filename); ...@@ -178,11 +198,11 @@ Oid lo_import(PGconn *conn, const char *filename);
</para> </para>
<para> <para>
<indexterm><primary>lo_import_with_oid</></>
The function The function
<synopsis> <synopsis>
Oid lo_import_with_oid(PGconn *conn, const char *filename, Oid lobjId); Oid lo_import_with_oid(PGconn *conn, const char *filename, Oid lobjId);
</synopsis> </synopsis>
<indexterm><primary>lo_import_with_oid</></>
also imports a new large object. The OID to be assigned can be also imports a new large object. The OID to be assigned can be
specified by <replaceable class="parameter">lobjId</replaceable>; specified by <replaceable class="parameter">lobjId</replaceable>;
if so, failure occurs if that OID is already in use for some large if so, failure occurs if that OID is already in use for some large
...@@ -204,12 +224,12 @@ Oid lo_import_with_oid(PGconn *conn, const char *filename, Oid lobjId); ...@@ -204,12 +224,12 @@ Oid lo_import_with_oid(PGconn *conn, const char *filename, Oid lobjId);
<title>Exporting a Large Object</title> <title>Exporting a Large Object</title>
<para> <para>
<indexterm><primary>lo_export</></>
To export a large object To export a large object
into an operating system file, call into an operating system file, call
<synopsis> <synopsis>
int lo_export(PGconn *conn, Oid lobjId, const char *filename); int lo_export(PGconn *conn, Oid lobjId, const char *filename);
</synopsis> </synopsis>
<indexterm><primary>lo_export</></>
The <parameter>lobjId</parameter> argument specifies the OID of the large The <parameter>lobjId</parameter> argument specifies the OID of the large
object to export and the <parameter>filename</parameter> argument object to export and the <parameter>filename</parameter> argument
specifies the operating system name of the file. Note that the file is specifies the operating system name of the file. Note that the file is
...@@ -222,24 +242,23 @@ int lo_export(PGconn *conn, Oid lobjId, const char *filename); ...@@ -222,24 +242,23 @@ int lo_export(PGconn *conn, Oid lobjId, const char *filename);
<title>Opening an Existing Large Object</title> <title>Opening an Existing Large Object</title>
<para> <para>
<indexterm><primary>lo_open</></>
To open an existing large object for reading or writing, call To open an existing large object for reading or writing, call
<synopsis> <synopsis>
int lo_open(PGconn *conn, Oid lobjId, int mode); int lo_open(PGconn *conn, Oid lobjId, int mode);
</synopsis> </synopsis>
<indexterm><primary>lo_open</></>
The <parameter>lobjId</parameter> argument specifies the OID of the large The <parameter>lobjId</parameter> argument specifies the OID of the large
object to open. The <parameter>mode</parameter> bits control whether the object to open. The <parameter>mode</parameter> bits control whether the
object is opened for reading (<symbol>INV_READ</>), writing object is opened for reading (<symbol>INV_READ</>), writing
(<symbol>INV_WRITE</symbol>), or both. (<symbol>INV_WRITE</symbol>), or both.
(These symbolic constants are defined (These symbolic constants are defined
in the header file <filename>libpq/libpq-fs.h</filename>.) in the header file <filename>libpq/libpq-fs.h</filename>.)
A large object cannot be opened before it is created.
<function>lo_open</function> returns a (non-negative) large object <function>lo_open</function> returns a (non-negative) large object
descriptor for later use in <function>lo_read</function>, descriptor for later use in <function>lo_read</function>,
<function>lo_write</function>, <function>lo_lseek</function>, <function>lo_write</function>, <function>lo_lseek</function>,
<function>lo_lseek64</function>, <function>lo_tell</function>, <function>lo_lseek64</function>, <function>lo_tell</function>,
<function>lo_tell64</function>, <function>lo_truncate</function>, <function>lo_tell64</function>, <function>lo_truncate</function>,
<function>lo_truncate64</function>, and <function>lo_close</function>. <function>lo_truncate64</function>, and <function>lo_close</function>.
The descriptor is only valid for The descriptor is only valid for
the duration of the current transaction. the duration of the current transaction.
On failure, -1 is returned. On failure, -1 is returned.
...@@ -274,17 +293,17 @@ inv_fd = lo_open(conn, inv_oid, INV_READ|INV_WRITE); ...@@ -274,17 +293,17 @@ inv_fd = lo_open(conn, inv_oid, INV_READ|INV_WRITE);
<title>Writing Data to a Large Object</title> <title>Writing Data to a Large Object</title>
<para> <para>
<indexterm><primary>lo_write</></>
The function The function
<synopsis> <synopsis>
int lo_write(PGconn *conn, int fd, const char *buf, size_t len); int lo_write(PGconn *conn, int fd, const char *buf, size_t len);
</synopsis> </synopsis>
<indexterm><primary>lo_write</></> writes writes <parameter>len</parameter> bytes from <parameter>buf</parameter>
<parameter>len</parameter> bytes from <parameter>buf</parameter>
to large object descriptor <parameter>fd</>. The <parameter>fd</parameter> to large object descriptor <parameter>fd</>. The <parameter>fd</parameter>
argument must have been returned by a previous argument must have been returned by a previous
<function>lo_open</function>. The number of bytes actually <function>lo_open</function>. The number of bytes actually
written is returned. In the event of an error, the return value written is returned. In the event of an error, the return value
is negative. is -1.
</para> </para>
</sect2> </sect2>
...@@ -292,17 +311,17 @@ int lo_write(PGconn *conn, int fd, const char *buf, size_t len); ...@@ -292,17 +311,17 @@ int lo_write(PGconn *conn, int fd, const char *buf, size_t len);
<title>Reading Data from a Large Object</title> <title>Reading Data from a Large Object</title>
<para> <para>
<indexterm><primary>lo_read</></>
The function The function
<synopsis> <synopsis>
int lo_read(PGconn *conn, int fd, char *buf, size_t len); int lo_read(PGconn *conn, int fd, char *buf, size_t len);
</synopsis> </synopsis>
<indexterm><primary>lo_read</></> reads reads <parameter>len</parameter> bytes from large object descriptor
<parameter>len</parameter> bytes from large object descriptor
<parameter>fd</parameter> into <parameter>buf</parameter>. The <parameter>fd</parameter> into <parameter>buf</parameter>. The
<parameter>fd</parameter> argument must have been returned by a <parameter>fd</parameter> argument must have been returned by a
previous <function>lo_open</function>. The number of bytes previous <function>lo_open</function>. The number of bytes
actually read is returned. In the event of an error, the return actually read is returned. In the event of an error, the return
value is negative. value is -1.
</para> </para>
</sect2> </sect2>
...@@ -310,13 +329,13 @@ int lo_read(PGconn *conn, int fd, char *buf, size_t len); ...@@ -310,13 +329,13 @@ int lo_read(PGconn *conn, int fd, char *buf, size_t len);
<title>Seeking in a Large Object</title> <title>Seeking in a Large Object</title>
<para> <para>
<indexterm><primary>lo_lseek</></>
To change the current read or write location associated with a To change the current read or write location associated with a
large object descriptor, call large object descriptor, call
<synopsis> <synopsis>
int lo_lseek(PGconn *conn, int fd, int offset, int whence); int lo_lseek(PGconn *conn, int fd, int offset, int whence);
pg_int64 lo_lseek64(PGconn *conn, int fd, pg_int64 offset, int whence);
</synopsis> </synopsis>
<indexterm><primary>lo_lseek</></> This function moves the This function moves the
current location pointer for the large object descriptor identified by current location pointer for the large object descriptor identified by
<parameter>fd</> to the new location specified by <parameter>fd</> to the new location specified by
<parameter>offset</>. The valid values for <parameter>whence</> <parameter>offset</>. The valid values for <parameter>whence</>
...@@ -324,14 +343,27 @@ pg_int64 lo_lseek64(PGconn *conn, int fd, pg_int64 offset, int whence); ...@@ -324,14 +343,27 @@ pg_int64 lo_lseek64(PGconn *conn, int fd, pg_int64 offset, int whence);
<symbol>SEEK_CUR</> (seek from current position), and <symbol>SEEK_CUR</> (seek from current position), and
<symbol>SEEK_END</> (seek from object end). The return value is <symbol>SEEK_END</> (seek from object end). The return value is
the new location pointer, or -1 on error. the new location pointer, or -1 on error.
<indexterm><primary>lo_lseek64</></> <function>lo_lseek64</function>
is a function for large objects larger than 2GB. <symbol>pg_int64</>
is defined as 8-byte integer type.
</para> </para>
<para>
<indexterm><primary>lo_lseek64</></>
When dealing with large objects that might exceed 2GB in size,
instead use
<synopsis>
pg_int64 lo_lseek64(PGconn *conn, int fd, pg_int64 offset, int whence);
</synopsis>
This function has the same behavior
as <function>lo_lseek</function>, but it can accept an
<parameter>offset</> larger than 2GB and/or deliver a result larger
than 2GB.
Note that <function>lo_lseek</function> will fail if the new location
pointer would be greater than 2GB.
</para>
<para> <para>
<function>lo_lseek64</> is new as of <productname>PostgreSQL</productname> <function>lo_lseek64</> is new as of <productname>PostgreSQL</productname>
9.3; if this function is run against an older server version, it will 9.3. If this function is run against an older server version, it will
fail and return a negative value. fail and return -1.
</para> </para>
</sect2> </sect2>
...@@ -340,21 +372,33 @@ pg_int64 lo_lseek64(PGconn *conn, int fd, pg_int64 offset, int whence); ...@@ -340,21 +372,33 @@ pg_int64 lo_lseek64(PGconn *conn, int fd, pg_int64 offset, int whence);
<title>Obtaining the Seek Position of a Large Object</title> <title>Obtaining the Seek Position of a Large Object</title>
<para> <para>
<indexterm><primary>lo_tell</></>
To obtain the current read or write location of a large object descriptor, To obtain the current read or write location of a large object descriptor,
call call
<synopsis> <synopsis>
int lo_tell(PGconn *conn, int fd); int lo_tell(PGconn *conn, int fd);
</synopsis>
If there is an error, the return value is -1.
</para>
<para>
<indexterm><primary>lo_tell64</></>
When dealing with large objects that might exceed 2GB in size,
instead use
<synopsis>
pg_int64 lo_tell64(PGconn *conn, int fd); pg_int64 lo_tell64(PGconn *conn, int fd);
</synopsis> </synopsis>
<indexterm><primary>lo_tell</></> If there is an error, the This function has the same behavior
return value is negative. as <function>lo_tell</function>, but it can deliver a result larger
<indexterm><primary>lo_tell64</></> <function>lo_tell64</function> is than 2GB.
a function for large objects larger than 2GB. Note that <function>lo_tell</function> will fail if the current
read/write location is greater than 2GB.
</para> </para>
<para> <para>
<function>lo_tell64</> is new as of <productname>PostgreSQL</productname> <function>lo_tell64</> is new as of <productname>PostgreSQL</productname>
9.3; if this function is run against an older server version, it will 9.3. If this function is run against an older server version, it will
fail and return a negative value. fail and return -1.
</para> </para>
</sect2> </sect2>
...@@ -362,39 +406,48 @@ pg_int64 lo_tell64(PGconn *conn, int fd); ...@@ -362,39 +406,48 @@ pg_int64 lo_tell64(PGconn *conn, int fd);
<title>Truncating a Large Object</title> <title>Truncating a Large Object</title>
<para> <para>
<indexterm><primary>lo_truncate</></>
To truncate a large object to a given length, call To truncate a large object to a given length, call
<synopsis> <synopsis>
int lo_truncate(PGcon *conn, int fd, size_t len); int lo_truncate(PGcon *conn, int fd, size_t len);
int lo_truncate64(PGcon *conn, int fd, pg_int64 len);
</synopsis> </synopsis>
<indexterm><primary>lo_truncate</></> truncates the large object This function truncates the large object
descriptor <parameter>fd</> to length <parameter>len</>. The descriptor <parameter>fd</> to length <parameter>len</>. The
<parameter>fd</parameter> argument must have been returned by a <parameter>fd</parameter> argument must have been returned by a
previous <function>lo_open</function>. If <parameter>len</> is previous <function>lo_open</function>. If <parameter>len</> is
greater than the current large object length, the large object greater than the large object's current length, the large object
is extended with null bytes ('\0'). is extended with null bytes ('\0').
<indexterm><primary>lo_truncate64</></> <function>lo_truncate64</function> On success, <function>lo_truncate</function> returns
is a function for large objects larger than 2GB. zero. On error, the return value is -1.
</para> </para>
<para> <para>
The file offset is not changed. The read/write location associated with the descriptor
<parameter>fd</parameter> is not changed.
</para> </para>
<para> <para>
On success <function>lo_truncate</function> and <function>lo_truncate64</function> returns <indexterm><primary>lo_truncate64</></>
zero. On error, the return value is negative. When dealing with large objects that might exceed 2GB in size,
instead use
<synopsis>
int lo_truncate64(PGcon *conn, int fd, pg_int64 len);
</synopsis>
This function has the same
behavior as <function>lo_truncate</function>, but it can accept a
<parameter>len</> value exceeding 2GB.
</para> </para>
<para> <para>
<function>lo_truncate</> is new as of <productname>PostgreSQL</productname> <function>lo_truncate</> is new as of <productname>PostgreSQL</productname>
8.3; if this function is run against an older server version, it will 8.3; if this function is run against an older server version, it will
fail and return a negative value. fail and return -1.
</para> </para>
<para> <para>
<function>lo_truncate64</> is new as of <productname>PostgreSQL</productname> <function>lo_truncate64</> is new as of <productname>PostgreSQL</productname>
9.3; if this function is run against an older server version, it will 9.3; if this function is run against an older server version, it will
fail and return a negative value. fail and return -1.
</para> </para>
</sect2> </sect2>
...@@ -402,14 +455,15 @@ int lo_truncate64(PGcon *conn, int fd, pg_int64 len); ...@@ -402,14 +455,15 @@ int lo_truncate64(PGcon *conn, int fd, pg_int64 len);
<title>Closing a Large Object Descriptor</title> <title>Closing a Large Object Descriptor</title>
<para> <para>
<indexterm><primary>lo_close</></>
A large object descriptor can be closed by calling A large object descriptor can be closed by calling
<synopsis> <synopsis>
int lo_close(PGconn *conn, int fd); int lo_close(PGconn *conn, int fd);
</synopsis> </synopsis>
<indexterm><primary>lo_close</></> where <parameter>fd</> is a where <parameter>fd</> is a
large object descriptor returned by <function>lo_open</function>. large object descriptor returned by <function>lo_open</function>.
On success, <function>lo_close</function> returns zero. On On success, <function>lo_close</function> returns zero. On
error, the return value is negative. error, the return value is -1.
</para> </para>
<para> <para>
...@@ -422,12 +476,12 @@ int lo_close(PGconn *conn, int fd); ...@@ -422,12 +476,12 @@ int lo_close(PGconn *conn, int fd);
<title>Removing a Large Object</title> <title>Removing a Large Object</title>
<para> <para>
<indexterm><primary>lo_unlink</></>
To remove a large object from the database, call To remove a large object from the database, call
<synopsis> <synopsis>
int lo_unlink(PGconn *conn, Oid lobjId); int lo_unlink(PGconn *conn, Oid lobjId);
</synopsis> </synopsis>
<indexterm><primary>lo_unlink</></> The The <parameter>lobjId</parameter> argument specifies the OID of the
<parameter>lobjId</parameter> argument specifies the OID of the
large object to remove. Returns 1 if successful, -1 on failure. large object to remove. Returns 1 if successful, -1 on failure.
</para> </para>
</sect2> </sect2>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment