From b73ecebf05041ab8643d6a4808ab807fb44f00b0 Mon Sep 17 00:00:00 2001 From: Tom Lane <tgl@sss.pgh.pa.us> Date: Thu, 30 Nov 2000 18:46:42 +0000 Subject: [PATCH] Remove obsolete claim that char(n) is more efficient than other text types. --- doc/FAQ | 14 ++++++-------- doc/src/FAQ/FAQ.html | 20 +++++++++----------- 2 files changed, 15 insertions(+), 19 deletions(-) diff --git a/doc/FAQ b/doc/FAQ index 403808f7bff..11a4783ab87 100644 --- a/doc/FAQ +++ b/doc/FAQ @@ -811,19 +811,17 @@ Type Internal Name Notes "char" char 1 character CHAR(#) bpchar blank padded to the specified fixed length VARCHAR(#) varchar size specifies maximum length, no padding -TEXT text length limited only by maximum row length -BYTEA bytea variable-length array of bytes +TEXT text no specific upper limit on length +BYTEA bytea variable-length byte array (null-safe) You will see the internal name when examining system catalogs and in some error messages. The last four types above are "varlena" types (i.e., the first four - bytes are the length, followed by the data). char(#) allocates the - maximum number of bytes no matter how much data is stored in the - field. text, varchar(#), and bytea all have variable length on the - disk, and because of this, there is a small performance penalty for - using them. Specifically, the penalty is for access to all columns - after the first column of this type. + bytes on disk are the length, followed by the data). Thus the actual + space used is slightly greater than the declared size. However, these + data types are also subject to compression or being stored out-of-line + by TOAST, so the space on disk might also be less than expected. 4.16.1) How do I create a serial/auto-incrementing field? diff --git a/doc/src/FAQ/FAQ.html b/doc/src/FAQ/FAQ.html index 585807e6ab9..1123086be9a 100644 --- a/doc/src/FAQ/FAQ.html +++ b/doc/src/FAQ/FAQ.html @@ -534,7 +534,7 @@ A report generator? An embedded query language interface?</H4><P> We have a nice graphical user interface called <I>pgaccess,</I> which is shipped as part of the distribution. <I>Pgaccess</I> also has a report -generator. The Web page is <A HREF= +generator. The Web page is <A HREF="" "http://www.flex.ro/pgaccess">http://www.flex.ro/pgaccess</A><P> We also include <I>ecpg,</I> which is an embedded SQL query language interface for @@ -996,20 +996,18 @@ Type Internal Name Notes "char" char 1 character CHAR(#) bpchar blank padded to the specified fixed length VARCHAR(#) varchar size specifies maximum length, no padding -TEXT text length limited only by maximum row length -BYTEA bytea variable-length array of bytes +TEXT text no specific upper limit on length +BYTEA bytea variable-length byte array (null-safe) </PRE><P> You will see the internal name when examining system catalogs and in some error messages.<P> - -The last four types above are "varlena" types (i.e., the first four bytes -are the length, followed by the data). <I>char(#)</I> allocates the -maximum number of bytes no matter how much data is stored in the field. -<I>text, varchar(#),</I> and <I>bytea</I> all have variable length on the disk, -and because of this, there is a small performance penalty for using -them. Specifically, the penalty is for access to all columns after the -first column of this type.<P> + +The last four types above are "varlena" types (i.e., the first four +bytes on disk are the length, followed by the data). Thus the actual +space used is slightly greater than the declared size. However, these +data types are also subject to compression or being stored out-of-line +by TOAST, so the space on disk might also be less than expected.<P> <H4><A NAME="4.16.1">4.16.1</A>) How do I create a -- GitLab