Commit c6c1a6e2 authored by Olivier Bertrand's avatar Olivier Bertrand

- Fix potential bug in MYSQLCOL::WriteColumn: ShowValue was call with

  *Bind->length instead of Bind->buffer_length

modified:
  storage/connect/tabmysql.cpp
parent b5130b5b
...@@ -767,11 +767,6 @@ int TDBMYSQL::BindColumns(PGLOBAL g) ...@@ -767,11 +767,6 @@ int TDBMYSQL::BindColumns(PGLOBAL g)
} // endif prep } // endif prep
#endif // MYSQL_PREPARED_STATEMENTS #endif // MYSQL_PREPARED_STATEMENTS
for (PMYCOL colp = (PMYCOL)Columns; colp; colp = (PMYCOL)colp->Next)
if (colp->Buf_Type == TYPE_DATE)
// Format must match DATETIME MySQL type
((DTVAL*)colp->GetValue())->SetFormat(g, "YYYY-MM-DD hh:mm:ss", 19);
return RC_OK; return RC_OK;
} // end of BindColumns } // end of BindColumns
...@@ -801,6 +796,14 @@ bool TDBMYSQL::OpenDB(PGLOBAL g) ...@@ -801,6 +796,14 @@ bool TDBMYSQL::OpenDB(PGLOBAL g)
} // endif Connected } // endif Connected
/*********************************************************************/
/* Take care of DATE columns. */
/*********************************************************************/
for (PMYCOL colp = (PMYCOL)Columns; colp; colp = (PMYCOL)colp->Next)
if (colp->Buf_Type == TYPE_DATE)
// Format must match DATETIME MySQL type
((DTVAL*)colp->GetValue())->SetFormat(g, "YYYY-MM-DD hh:mm:ss", 19);
/*********************************************************************/ /*********************************************************************/
/* Allocate whatever is used for getting results. */ /* Allocate whatever is used for getting results. */
/*********************************************************************/ /*********************************************************************/
...@@ -1191,10 +1194,6 @@ void MYSQLCOL::InitBind(PGLOBAL g) ...@@ -1191,10 +1194,6 @@ void MYSQLCOL::InitBind(PGLOBAL g)
memset(Bind, 0, sizeof(MYSQL_BIND)); memset(Bind, 0, sizeof(MYSQL_BIND));
if (Buf_Type == TYPE_DATE) { if (Buf_Type == TYPE_DATE) {
// Default format must match DATETIME MySQL type
// if (!((DTVAL*)Value)->IsFormatted())
((DTVAL*)Value)->SetFormat(g, "YYYY-MM-DD hh:mm:ss", 19);
Bind->buffer_type = PLGtoMYSQL(TYPE_STRING, false); Bind->buffer_type = PLGtoMYSQL(TYPE_STRING, false);
Bind->buffer = (char *)PlugSubAlloc(g,NULL, 20); Bind->buffer = (char *)PlugSubAlloc(g,NULL, 20);
Bind->buffer_length = 20; Bind->buffer_length = 20;
...@@ -1257,7 +1256,7 @@ void MYSQLCOL::WriteColumn(PGLOBAL g) ...@@ -1257,7 +1256,7 @@ void MYSQLCOL::WriteColumn(PGLOBAL g)
#if defined(MYSQL_PREPARED_STATEMENTS) #if defined(MYSQL_PREPARED_STATEMENTS)
if (((PTDBMY)To_Tdb)->Prep) { if (((PTDBMY)To_Tdb)->Prep) {
if (Buf_Type == TYPE_DATE) { if (Buf_Type == TYPE_DATE) {
Value->ShowValue((char *)Bind->buffer, (int)*Bind->length); Value->ShowValue((char *)Bind->buffer, (int)Bind->buffer_length);
Slen = strlen((char *)Bind->buffer); Slen = strlen((char *)Bind->buffer);
} else if (IsTypeChar(Buf_Type)) } else if (IsTypeChar(Buf_Type))
Slen = strlen(Value->GetCharValue()); Slen = strlen(Value->GetCharValue());
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment