From a08639049cdd6fb8bedbeb03e2eabe6ea9803561 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Wed, 10 Dec 2014 15:04:29 +0000 Subject: [PATCH] fix exception: nothing known about column "table.column", if "column" alone would work --- phpgwapi/inc/class.egw_db.inc.php | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/phpgwapi/inc/class.egw_db.inc.php b/phpgwapi/inc/class.egw_db.inc.php index 31865db4d3..bc03c740f3 100644 --- a/phpgwapi/inc/class.egw_db.inc.php +++ b/phpgwapi/inc/class.egw_db.inc.php @@ -7,7 +7,7 @@ * @package api * @subpackage db * @author Ralf Becker - * @copyright (c) 2003-13 by Ralf Becker + * @copyright (c) 2003-14 by Ralf Becker * @version $Id$ */ @@ -1507,16 +1507,22 @@ class egw_db { $keys[] = $this->name_quote($key); + $col = $key; + // fix "table.column" expressions, to not trigger exception, if column alone would work if (!is_int($key) && is_array($column_definitions) && !isset($column_definitions[$key])) { - throw new egw_exception_db_invalid_sql("db::column_data_implode('$glue',".print_r($array,True).",'$use_key',".print_r($only,True).",
".print_r($column_definitions,True)."
nothing known about column '$key'!"); + if (strpos($key, '.') !== false) list(, $col) = explode('.', $key); + if (!isset($column_definitions[$col])) + { + throw new egw_exception_db_invalid_sql("db::column_data_implode('$glue',".print_r($array,True).",'$use_key',".print_r($only,True).",
".print_r($column_definitions,True)."
nothing known about column '$key'!"); + } } - $column_type = is_array($column_definitions) ? @$column_definitions[$key]['type'] : False; - $not_null = is_array($column_definitions) && isset($column_definitions[$key]['nullable']) ? !$column_definitions[$key]['nullable'] : false; + $column_type = is_array($column_definitions) ? @$column_definitions[$col]['type'] : False; + $not_null = is_array($column_definitions) && isset($column_definitions[$col]['nullable']) ? !$column_definitions[$col]['nullable'] : false; if ($truncate_varchar) { - $maxlength = $column_definitions[$key]['type'] == 'varchar' ? $column_definitions[$key]['precision'] : null; + $maxlength = $column_definitions[$col]['type'] == 'varchar' ? $column_definitions[$col]['precision'] : null; } // dont use IN ( ), if there's only one value, it's slower for MySQL if (is_array($data) && count($data) == 1)