2006-06-29 23:04:39 +00:00
|
|
|
<?php
|
|
|
|
require_once("Condition.php");
|
|
|
|
|
|
|
|
class Doctrine_Query_Having extends Doctrine_Query_Condition {
|
|
|
|
/**
|
|
|
|
* DQL Aggregate Function parser
|
|
|
|
*
|
|
|
|
* @param string $func
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
private function parseAggregateFunction($func) {
|
|
|
|
$pos = strpos($func,"(");
|
|
|
|
|
2006-12-29 14:01:31 +00:00
|
|
|
if ($pos !== false) {
|
2006-06-29 23:04:39 +00:00
|
|
|
$funcs = array();
|
|
|
|
|
|
|
|
$name = substr($func, 0, $pos);
|
|
|
|
$func = substr($func, ($pos + 1), -1);
|
|
|
|
$params = Doctrine_Query::bracketExplode($func, ",", "(", ")");
|
|
|
|
|
2006-12-29 14:01:31 +00:00
|
|
|
foreach ($params as $k => $param) {
|
2006-06-29 23:04:39 +00:00
|
|
|
$params[$k] = $this->parseAggregateFunction($param);
|
|
|
|
}
|
|
|
|
|
|
|
|
$funcs = $name."(".implode(", ", $params).")";
|
|
|
|
|
|
|
|
return $funcs;
|
|
|
|
|
|
|
|
} else {
|
2006-12-29 14:01:31 +00:00
|
|
|
if ( ! is_numeric($func)) {
|
2006-06-29 23:04:39 +00:00
|
|
|
$a = explode(".",$func);
|
|
|
|
$field = array_pop($a);
|
|
|
|
$reference = implode(".",$a);
|
|
|
|
$table = $this->query->load($reference, false);
|
|
|
|
$func = $this->query->getTableAlias($reference).".".$field;
|
|
|
|
|
|
|
|
return $func;
|
|
|
|
} else {
|
|
|
|
return $func;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* load
|
|
|
|
* returns the parsed query part
|
|
|
|
*
|
|
|
|
* @param string $having
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
final public function load($having) {
|
2006-12-28 11:56:24 +00:00
|
|
|
$e = Doctrine_Query::bracketExplode($having, ' ', '(', ')');
|
2006-06-29 23:04:39 +00:00
|
|
|
|
|
|
|
$r = array_shift($e);
|
2006-12-28 11:56:24 +00:00
|
|
|
$t = explode('(', $r);
|
2006-06-29 23:04:39 +00:00
|
|
|
|
|
|
|
$count = count($t);
|
|
|
|
$r = $this->parseAggregateFunction($r);
|
|
|
|
$operator = array_shift($e);
|
2006-12-28 11:56:24 +00:00
|
|
|
$value = implode(' ', $e);
|
|
|
|
$r .= ' ' . $operator . ' ' . $value;
|
2006-06-29 23:04:39 +00:00
|
|
|
|
|
|
|
return $r;
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* __toString
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function __toString() {
|
2006-12-28 11:56:24 +00:00
|
|
|
return ( ! empty($this->parts))?implode(' AND ', $this->parts):'';
|
2006-06-29 23:04:39 +00:00
|
|
|
}
|
|
|
|
}
|