mirror of
https://github.com/postgres/postgres.git
synced 2025-11-18 02:02:55 +03:00
Support multi-line headers in COPY FROM command.
The COPY FROM command now accepts a non-negative integer for the HEADER option, allowing multiple header lines to be skipped. This is useful when the input contains multi-line headers that should be ignored during data import. Author: Shinya Kato <shinya11.kato@gmail.com> Co-authored-by: Fujii Masao <masao.fujii@gmail.com> Reviewed-by: Yugo Nagata <nagata@sraoss.co.jp> Discussion: https://postgr.es/m/CAOzEurRPxfzbxqeOPF_AGnAUOYf=Wk0we+1LQomPNUNtyZGBZw@mail.gmail.com
This commit is contained in:
@@ -771,21 +771,30 @@ static pg_attribute_always_inline bool
|
||||
NextCopyFromRawFieldsInternal(CopyFromState cstate, char ***fields, int *nfields, bool is_csv)
|
||||
{
|
||||
int fldct;
|
||||
bool done;
|
||||
bool done = false;
|
||||
|
||||
/* only available for text or csv input */
|
||||
Assert(!cstate->opts.binary);
|
||||
|
||||
/* on input check that the header line is correct if needed */
|
||||
if (cstate->cur_lineno == 0 && cstate->opts.header_line)
|
||||
if (cstate->cur_lineno == 0 && cstate->opts.header_line != COPY_HEADER_FALSE)
|
||||
{
|
||||
ListCell *cur;
|
||||
TupleDesc tupDesc;
|
||||
int lines_to_skip = cstate->opts.header_line;
|
||||
|
||||
/* If set to "match", one header line is skipped */
|
||||
if (cstate->opts.header_line == COPY_HEADER_MATCH)
|
||||
lines_to_skip = 1;
|
||||
|
||||
tupDesc = RelationGetDescr(cstate->rel);
|
||||
|
||||
cstate->cur_lineno++;
|
||||
done = CopyReadLine(cstate, is_csv);
|
||||
for (int i = 0; i < lines_to_skip; i++)
|
||||
{
|
||||
cstate->cur_lineno++;
|
||||
if ((done = CopyReadLine(cstate, is_csv)))
|
||||
break;
|
||||
}
|
||||
|
||||
if (cstate->opts.header_line == COPY_HEADER_MATCH)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user