mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
- Commit merged files
modified: storage/connect/colblk.h storage/connect/ha_connect.cc storage/connect/mysql-test/connect/r/csv.result storage/connect/mysql-test/connect/r/dbf.result storage/connect/mysql-test/connect/r/fix.result storage/connect/mysql-test/connect/r/ini.result storage/connect/mysql-test/connect/r/vec.result storage/connect/mysql-test/connect/t/csv.test storage/connect/mysql-test/connect/t/dbf.test storage/connect/mysql-test/connect/t/fix.test storage/connect/mysql-test/connect/t/ini.test storage/connect/mysql-test/connect/t/vec.test storage/connect/reldef.h storage/connect/tabdos.cpp storage/connect/tabdos.h storage/connect/tabfmt.cpp storage/connect/tabmysql.cpp
This commit is contained in:
@@ -597,7 +597,7 @@ int TDBCSV::EstimatedLength(PGLOBAL g)
|
||||
PCSVCOL colp;
|
||||
|
||||
for (colp = (PCSVCOL)Columns; colp; colp = (PCSVCOL)colp->Next)
|
||||
if (!colp->IsSpecial()) // Not a pseudo column
|
||||
if (!colp->IsSpecial() && !colp->IsVirtual()) // A true column
|
||||
Fields = MY_MAX(Fields, (int)colp->Fldnum);
|
||||
|
||||
if (Columns)
|
||||
@@ -640,7 +640,7 @@ bool TDBCSV::OpenDB(PGLOBAL g)
|
||||
if (!Fields) // May have been set in TABFMT::OpenDB
|
||||
if (Mode != MODE_UPDATE && Mode != MODE_INSERT) {
|
||||
for (colp = (PCSVCOL)Columns; colp; colp = (PCSVCOL)colp->Next)
|
||||
if (!colp->IsSpecial()) // Not a pseudo column
|
||||
if (!colp->IsSpecial() && !colp->IsVirtual())
|
||||
Fields = MY_MAX(Fields, (int)colp->Fldnum);
|
||||
|
||||
if (Columns)
|
||||
@@ -648,7 +648,8 @@ bool TDBCSV::OpenDB(PGLOBAL g)
|
||||
|
||||
} else
|
||||
for (cdp = tdp->GetCols(); cdp; cdp = cdp->GetNext())
|
||||
Fields++;
|
||||
if (!cdp->IsVirtual())
|
||||
Fields++;
|
||||
|
||||
Offset = (int*)PlugSubAlloc(g, NULL, sizeof(int) * Fields);
|
||||
Fldlen = (int*)PlugSubAlloc(g, NULL, sizeof(int) * Fields);
|
||||
@@ -671,25 +672,27 @@ bool TDBCSV::OpenDB(PGLOBAL g)
|
||||
|
||||
if (Field)
|
||||
// Prepare writing fields
|
||||
if (Mode != MODE_UPDATE)
|
||||
for (colp = (PCSVCOL)Columns; colp; colp = (PCSVCOL)colp->Next) {
|
||||
i = colp->Fldnum;
|
||||
len = colp->GetLength();
|
||||
Field[i] = (PSZ)PlugSubAlloc(g, NULL, len + 1);
|
||||
Field[i][len] = '\0';
|
||||
Fldlen[i] = len;
|
||||
Fldtyp[i] = IsTypeNum(colp->GetResultType());
|
||||
} // endfor colp
|
||||
if (Mode != MODE_UPDATE) {
|
||||
for (colp = (PCSVCOL)Columns; colp; colp = (PCSVCOL)colp->Next)
|
||||
if (!colp->IsSpecial() && !colp->IsVirtual()) {
|
||||
i = colp->Fldnum;
|
||||
len = colp->GetLength();
|
||||
Field[i] = (PSZ)PlugSubAlloc(g, NULL, len + 1);
|
||||
Field[i][len] = '\0';
|
||||
Fldlen[i] = len;
|
||||
Fldtyp[i] = IsTypeNum(colp->GetResultType());
|
||||
} // endif colp
|
||||
|
||||
else // MODE_UPDATE
|
||||
for (cdp = tdp->GetCols(); cdp; cdp = cdp->GetNext()) {
|
||||
i = cdp->GetOffset() - 1;
|
||||
len = cdp->GetLength();
|
||||
Field[i] = (PSZ)PlugSubAlloc(g, NULL, len + 1);
|
||||
Field[i][len] = '\0';
|
||||
Fldlen[i] = len;
|
||||
Fldtyp[i] = IsTypeNum(cdp->GetType());
|
||||
} // endfor colp
|
||||
} else // MODE_UPDATE
|
||||
for (cdp = tdp->GetCols(); cdp; cdp = cdp->GetNext())
|
||||
if (!cdp->IsVirtual()) {
|
||||
i = cdp->GetOffset() - 1;
|
||||
len = cdp->GetLength();
|
||||
Field[i] = (PSZ)PlugSubAlloc(g, NULL, len + 1);
|
||||
Field[i][len] = '\0';
|
||||
Fldlen[i] = len;
|
||||
Fldtyp[i] = IsTypeNum(cdp->GetType());
|
||||
} // endif cdp
|
||||
|
||||
} // endif Use
|
||||
|
||||
@@ -1100,7 +1103,7 @@ bool TDBFMT::OpenDB(PGLOBAL g)
|
||||
PDOSDEF tdp = (PDOSDEF)To_Def;
|
||||
|
||||
for (colp = (PCSVCOL)Columns; colp; colp = (PCSVCOL)colp->Next)
|
||||
if (!colp->IsSpecial()) // Not a pseudo column
|
||||
if (!colp->IsSpecial() && !colp->IsVirtual()) // a true column
|
||||
Fields = MY_MAX(Fields, (int)colp->Fldnum);
|
||||
|
||||
if (Columns)
|
||||
@@ -1114,7 +1117,7 @@ bool TDBFMT::OpenDB(PGLOBAL g)
|
||||
|
||||
// Get the column formats
|
||||
for (cdp = tdp->GetCols(); cdp; cdp = cdp->GetNext())
|
||||
if ((i = cdp->GetOffset() - 1) < Fields) {
|
||||
if (!cdp->IsVirtual() && (i = cdp->GetOffset() - 1) < Fields) {
|
||||
if (!(pfm = cdp->GetFmt())) {
|
||||
sprintf(g->Message, MSG(NO_FLD_FORMAT), i + 1, Name);
|
||||
return true;
|
||||
@@ -1336,6 +1339,11 @@ void CSVCOL::ReadColumn(PGLOBAL g)
|
||||
// Field have been copied in TDB Field array
|
||||
PSZ fp = tdbp->Field[Fldnum];
|
||||
|
||||
if (Dsp)
|
||||
for (int i = 0; fp[i]; i++)
|
||||
if (fp[i] == Dsp)
|
||||
fp[i] = '.';
|
||||
|
||||
Value->SetValue_psz(fp);
|
||||
|
||||
// Set null when applicable
|
||||
@@ -1383,7 +1391,10 @@ void CSVCOL::WriteColumn(PGLOBAL g)
|
||||
sprintf(g->Message, MSG(BAD_FLD_LENGTH), Name, p, flen,
|
||||
tdbp->RowNumber(g), tdbp->GetFile(g));
|
||||
longjmp(g->jumper[g->jump_level], 34);
|
||||
} // endif
|
||||
} else if (Dsp)
|
||||
for (int i = 0; p[i]; i++)
|
||||
if (p[i] == '.')
|
||||
p[i] = Dsp;
|
||||
|
||||
if (trace > 1)
|
||||
htrc("buffer=%s\n", p);
|
||||
|
Reference in New Issue
Block a user