mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Pass modern COPY syntax to backend, since copy (query) does not accept old syntax. Per complaint from Michael Fuhr.
This commit is contained in:
		| @@ -3,7 +3,7 @@ | |||||||
|  * |  * | ||||||
|  * Copyright (c) 2000-2007, PostgreSQL Global Development Group |  * Copyright (c) 2000-2007, PostgreSQL Global Development Group | ||||||
|  * |  * | ||||||
|  * $PostgreSQL: pgsql/src/bin/psql/copy.c,v 1.72 2007/01/05 22:19:49 momjian Exp $ |  * $PostgreSQL: pgsql/src/bin/psql/copy.c,v 1.73 2007/02/05 15:22:18 adunstan Exp $ | ||||||
|  */ |  */ | ||||||
| #include "postgres_fe.h" | #include "postgres_fe.h" | ||||||
| #include "copy.h" | #include "copy.h" | ||||||
| @@ -268,7 +268,7 @@ parse_slash_copy(const char *args) | |||||||
| 					0, false, false, pset.encoding); | 					0, false, false, pset.encoding); | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * Allows old COPY syntax for backward compatibility 2002-06-19 | 	 * Allows old COPY syntax for backward compatibility. | ||||||
| 	 */ | 	 */ | ||||||
| 	if (token && pg_strcasecmp(token, "using") == 0) | 	if (token && pg_strcasecmp(token, "using") == 0) | ||||||
| 	{ | 	{ | ||||||
| @@ -480,32 +480,28 @@ do_copy(const char *args) | |||||||
|  |  | ||||||
| 	printfPQExpBuffer(&query, "COPY "); | 	printfPQExpBuffer(&query, "COPY "); | ||||||
|  |  | ||||||
| 	/* Uses old COPY syntax for backward compatibility 2002-06-19 */ |  | ||||||
| 	if (options->binary) |  | ||||||
| 		appendPQExpBuffer(&query, "BINARY "); |  | ||||||
|  |  | ||||||
| 	appendPQExpBuffer(&query, "%s ", options->table); | 	appendPQExpBuffer(&query, "%s ", options->table); | ||||||
|  |  | ||||||
| 	if (options->column_list) | 	if (options->column_list) | ||||||
| 		appendPQExpBuffer(&query, "%s ", options->column_list); | 		appendPQExpBuffer(&query, "%s ", options->column_list); | ||||||
|  |  | ||||||
| 	/* Uses old COPY syntax for backward compatibility 2002-06-19 */ |  | ||||||
| 	if (options->oids) |  | ||||||
| 		appendPQExpBuffer(&query, "WITH OIDS "); |  | ||||||
|  |  | ||||||
| 	if (options->from) | 	if (options->from) | ||||||
| 		appendPQExpBuffer(&query, "FROM STDIN"); | 		appendPQExpBuffer(&query, "FROM STDIN"); | ||||||
| 	else | 	else | ||||||
| 		appendPQExpBuffer(&query, "TO STDOUT"); | 		appendPQExpBuffer(&query, "TO STDOUT"); | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/* Uses old COPY syntax for backward compatibility 2002-06-19 */ | 	if (options->binary) | ||||||
| 	if (options->delim) | 		appendPQExpBuffer(&query, " BINARY "); | ||||||
| 		emit_copy_option(&query, " USING DELIMITERS ", options->delim); |  | ||||||
|  | 	if (options->oids) | ||||||
|  | 		appendPQExpBuffer(&query, " OIDS "); | ||||||
|  |  | ||||||
|  | 	if (options->delim) | ||||||
|  | 		emit_copy_option(&query, " DELIMITER ", options->delim); | ||||||
|  |  | ||||||
| 	/* There is no backward-compatible CSV syntax */ |  | ||||||
| 	if (options->null) | 	if (options->null) | ||||||
| 		emit_copy_option(&query, " WITH NULL AS ", options->null); | 		emit_copy_option(&query, " NULL AS ", options->null); | ||||||
|  |  | ||||||
| 	if (options->csv_mode) | 	if (options->csv_mode) | ||||||
| 		appendPQExpBuffer(&query, " CSV"); | 		appendPQExpBuffer(&query, " CSV"); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user