diff options
author | Andrey Andreev <narf@devilix.net> | 2013-10-29 13:36:18 +0100 |
---|---|---|
committer | Andrey Andreev <narf@devilix.net> | 2013-10-29 13:36:18 +0100 |
commit | 5e3d48c21dea8a97dcea1b820ebc14700a336312 (patch) | |
tree | ea1f40ae5ff002eaf55f52ab287ff48ffe446ba5 /system/database | |
parent | 2d5ebf754546f680879831f58b9236d8d53af8b5 (diff) |
Fix a bug when multiple calls to QB's _compile_wh() or _compile_group_by() are required
Diffstat (limited to 'system/database')
-rw-r--r-- | system/database/DB_query_builder.php | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/system/database/DB_query_builder.php b/system/database/DB_query_builder.php index ebc9855bc..a73460394 100644 --- a/system/database/DB_query_builder.php +++ b/system/database/DB_query_builder.php @@ -2291,7 +2291,12 @@ abstract class CI_DB_query_builder extends CI_DB_driver { { for ($i = 0, $c = count($this->$qb_key); $i < $c; $i++) { - if ($this->{$qb_key}[$i]['escape'] === FALSE) + // Is this condition already compiled? + if (is_string($this->{$qb_key}[$i])) + { + continue; + } + elseif ($this->{$qb_key}[$i]['escape'] === FALSE) { $this->{$qb_key}[$i] = $this->{$qb_key}[$i]['condition']; continue; @@ -2361,6 +2366,12 @@ abstract class CI_DB_query_builder extends CI_DB_driver { { for ($i = 0, $c = count($this->qb_groupby); $i < $c; $i++) { + // Is it already compiled? + if (is_string($this->qb_groupby)) + { + continue; + } + $this->qb_groupby[$i] = ($this->qb_groupby[$i]['escape'] === FALSE OR $this->_is_literal($this->qb_groupby[$i]['field'])) ? $this->qb_groupby[$i]['field'] : $this->protect_identifiers($this->qb_groupby[$i]['field']); |