* ProjectManager: fix SQL error if searching for string containing numbers and underscore or percent

skip user-wildcards (*,?) in is_numeric test, but not SQL wildcards, which get escaped and give sql-error
This commit is contained in:
Ralf Becker 2013-08-14 08:03:09 +00:00
parent 9638679c97
commit 4c70450cad

View File

@ -1176,7 +1176,8 @@ class so_sql
$GLOBALS['egw']->db->quote($wildcard.str_replace(array('%','_','*','?'),array('\\%','\\_','%','_'),$token).$wildcard);
// Compare numeric token as equality for numeric columns
if(is_numeric(str_replace(array('%','_','*','?'), '', $token)))
// skip user-wildcards (*,?) in is_numeric test, but not SQL wildcards, which get escaped and give sql-error
if (is_numeric(str_replace(array('*','?'), '', $token)))
{
$numeric_filter = array();
foreach($numeric_columns as $col)
@ -1186,7 +1187,7 @@ class so_sql
// Token has a wildcard from user, use LIKE
$numeric_filter[] = "($col IS NOT NULL AND CAST($col AS CHAR) " .
$this->db->capabilities['case_insensitive_like'] . ' ' .
$GLOBALS['egw']->db->quote(str_replace(array('%','_','*','?'),array('\\%','\\_','%','_'),$token)) . ')';
$GLOBALS['egw']->db->quote(str_replace(array('*','?'), array('%','_'), $token)) . ')';
}
else
{