Commit 019c9e0a authored by Olivier Bertrand's avatar Olivier Bertrand

Fix assert error for where clause with UDF's

    was fixed in HA_CONNECT::CondFilter moving res= pval->val_str(&tmp)
    but this was wrong. Now res is only used for strings.
  modified:   storage/connect/ha_connect.cc
parent e939ea58
...@@ -2486,9 +2486,10 @@ PFIL ha_connect::CondFilter(PGLOBAL g, Item *cond) ...@@ -2486,9 +2486,10 @@ PFIL ha_connect::CondFilter(PGLOBAL g, Item *cond)
if (!i && (ismul)) if (!i && (ismul))
return NULL; return NULL;
switch (args[i]->real_type()) { switch (args[i]->real_type()) {
case COND::STRING_ITEM: case COND::STRING_ITEM:
pp->Value= PlugSubAllocStr(g, NULL, res->ptr(), res->length()); res= pval->val_str(&tmp);
pp->Value= PlugSubAllocStr(g, NULL, res->ptr(), res->length());
pp->Type= (pp->Value) ? TYPE_STRING : TYPE_ERROR; pp->Type= (pp->Value) ? TYPE_STRING : TYPE_ERROR;
break; break;
case COND::INT_ITEM: case COND::INT_ITEM:
...@@ -2517,12 +2518,8 @@ PFIL ha_connect::CondFilter(PGLOBAL g, Item *cond) ...@@ -2517,12 +2518,8 @@ PFIL ha_connect::CondFilter(PGLOBAL g, Item *cond)
return NULL; return NULL;
} // endswitch type } // endswitch type
// This was moved because cannot be done for FUNC_ITEM
if ((res= pval->val_str(&tmp)) == NULL)
return NULL; // To be clarified
if (trace) if (trace)
htrc("Value=%.*s\n", res->length(), res->ptr()); htrc("Value type=%hd\n", pp->Type);
// Append the value to the argument list // Append the value to the argument list
if (pprec) if (pprec)
......
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