|
|
@ -164,9 +164,10 @@ abstract class SqlModel extends Model |
|
|
|
* @param string $data Request |
|
|
|
* @param array $params Request parameters |
|
|
|
* @param CacheKey $cache_key Key for caching in |
|
|
|
* @param bool $returnNewInstance Return the instance of this filled from query |
|
|
|
* @return mixed |
|
|
|
*/ |
|
|
|
protected function fetch($data, $params = array(), $cache_key = null) |
|
|
|
protected function fetch($data, $params = array(), $cache_key = null, $returnFilledInstance = true) |
|
|
|
{ |
|
|
|
if (!$cache_key || !$result = $cache_key->get()) { |
|
|
|
$result = $this->query($data, $params)->fetch(); |
|
|
@ -174,6 +175,20 @@ abstract class SqlModel extends Model |
|
|
|
$cache_key->set($result); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if ($result && $returnFilledInstance) { |
|
|
|
$instance = new $this; |
|
|
|
|
|
|
|
foreach (get_object_vars($result) as $key => $value) { |
|
|
|
if ($key == 'table') { |
|
|
|
$key = 'table_field'; |
|
|
|
} |
|
|
|
$instance->$key = $value; |
|
|
|
} |
|
|
|
|
|
|
|
return $instance; |
|
|
|
} |
|
|
|
|
|
|
|
return $result; |
|
|
|
} |
|
|
|
|
|
|
@ -250,4 +265,4 @@ abstract class SqlModel extends Model |
|
|
|
{ |
|
|
|
return new SqlCriteria($this, $sql_expression, $sql_expression_params); |
|
|
|
} |
|
|
|
} |
|
|
|
} |