<!--
-$Header: /cvsroot/pgsql/doc/src/sgml/ref/copy.sgml,v 1.24 2001/09/13 15:55:24 petere Exp $
+$Header: /cvsroot/pgsql/doc/src/sgml/ref/copy.sgml,v 1.25 2001/12/04 21:19:57 tgl Exp $
Postgres documentation
-->
character with the keyword phrase USING DELIMITERS. Characters
in data fields which happen to match the delimiter character will
be backslash quoted.
- Note that the delimiter is always a single character.
- If multiple characters are specified in the delimiter string,
- only the first character is used.
</para>
<para>
*
*
* IDENTIFICATION
- * $Header: /cvsroot/pgsql/src/backend/commands/copy.c,v 1.143 2001/12/04 19:40:16 tgl Exp $
+ * $Header: /cvsroot/pgsql/src/backend/commands/copy.c,v 1.144 2001/12/04 21:19:57 tgl Exp $
*
*-------------------------------------------------------------------------
*/
if (pipe && binary)
elog(ERROR, "COPY BINARY is not supported to stdout or from stdin");
+ /*
+ * Presently, only single-character delimiter strings are supported.
+ */
+ if (strlen(delim) != 1)
+ elog(ERROR, "COPY delimiter must be a single character");
+
/*
* Set up variables to avoid per-attribute overhead.
*/
* Note that the caller should not pfree the string!
*
* *isnull is set true if a null attribute, else false.
- * delim is the string of acceptable delimiter characters(s).
+ * delim is the column delimiter string (currently always 1 character).
* *newline remembers whether we've seen a newline ending this tuple.
* null_print says how NULL values are represented
*/
CopyReadAttribute(FILE *fp, bool *isnull, char *delim, int *newline, char *null_print)
{
int c;
+ int delimc = delim[0];
#ifdef MULTIBYTE
int mblen;
*newline = 1;
break;
}
- if (strchr(delim, c))
+ if (c == delimc)
break;
if (c == '\\')
{