| Package | system.db.ar |
|---|---|
| Inheritance | class CJoinQuery |
| Since | 1.0 |
| Version | $Id$ |
| Source Code | framework/db/ar/CActiveFinder.php |
| Property | Type | Description | Defined By |
|---|---|---|---|
| conditions | array | list of WHERE clauses | CJoinQuery |
| distinct | boolean | whether to select distinct result set | CJoinQuery |
| elements | array | list of join element IDs (id=>true) | CJoinQuery |
| groups | array | list of GROUP BY clauses | CJoinQuery |
| havings | array | list of HAVING clauses | CJoinQuery |
| joins | array | list of join statement | CJoinQuery |
| limit | integer | row limit | CJoinQuery |
| offset | integer | row offset | CJoinQuery |
| orders | array | list of ORDER BY clauses | CJoinQuery |
| params | array | list of query parameters | CJoinQuery |
| selects | array | list of column selections | CJoinQuery |
| Method | Description | Defined By |
|---|---|---|
| __construct() | Constructor. | CJoinQuery |
| createCommand() | Creates the SQL statement. | CJoinQuery |
| join() | Joins with another join element | CJoinQuery |
list of WHERE clauses
whether to select distinct result set
list of join element IDs (id=>true)
list of GROUP BY clauses
list of HAVING clauses
list of join statement
row limit
row offset
list of ORDER BY clauses
list of query parameters
list of column selections
|
public void __construct(CJoinElement $joinElement, CDbCriteria $criteria=NULL)
| ||
| $joinElement | CJoinElement | The root join tree. |
| $criteria | CDbCriteria | the query criteria |
public function __construct($joinElement,$criteria=null)
{
if($criteria!==null)
{
$this->selects[]=$joinElement->getColumnSelect($criteria->select);
$this->joins[]=$joinElement->getTableNameWithAlias();
$this->joins[]=$criteria->join;
$this->conditions[]=$criteria->condition;
$this->orders[]=$criteria->order;
$this->groups[]=$criteria->group;
$this->havings[]=$criteria->having;
$this->limit=$criteria->limit;
$this->offset=$criteria->offset;
$this->params=$criteria->params;
if(!$this->distinct && $criteria->distinct)
$this->distinct=true;
}
else
{
$this->selects[]=$joinElement->getPrimaryKeySelect();
$this->joins[]=$joinElement->getTableNameWithAlias();
$this->conditions[]=$joinElement->getPrimaryKeyRange();
}
$this->elements[$joinElement->id]=true;
}
Constructor.
|
public string createCommand(CDbCommandBuilder $builder)
| ||
| $builder | CDbCommandBuilder | the command builder |
| {return} | string | the SQL statement |
public function createCommand($builder)
{
$sql=($this->distinct ? 'SELECT DISTINCT ':'SELECT ') . implode(', ',$this->selects);
$sql.=' FROM ' . implode(' ',$this->joins);
$conditions=array();
foreach($this->conditions as $condition)
if($condition!=='')
$conditions[]=$condition;
if($conditions!==array())
$sql.=' WHERE (' . implode(') AND (',$conditions).')';
$groups=array();
foreach($this->groups as $group)
if($group!=='')
$groups[]=$group;
if($groups!==array())
$sql.=' GROUP BY ' . implode(', ',$groups);
$havings=array();
foreach($this->havings as $having)
if($having!=='')
$havings[]=$having;
if($havings!==array())
$sql.=' HAVING (' . implode(') AND (',$havings).')';
$orders=array();
foreach($this->orders as $order)
if($order!=='')
$orders[]=$order;
if($orders!==array())
$sql.=' ORDER BY ' . implode(', ',$orders);
$sql=$builder->applyLimit($sql,$this->limit,$this->offset);
$command=$builder->getDbConnection()->createCommand($sql);
$builder->bindValues($command,$this->params);
return $command;
}
Creates the SQL statement.
|
public void join(CJoinElement $element)
| ||
| $element | CJoinElement | the element to be joined |
public function join($element)
{
$this->selects[]=$element->getColumnSelect($element->relation->select);
$this->conditions[]=$element->getCondition();
$this->orders[]=$element->getOrder();
$this->joins[]=$element->getJoinCondition();
$this->groups[]=$element->getGroupBy();
$this->havings[]=$element->getHaving();
if(is_array($element->relation->params))
{
if(is_array($this->params))
$this->params=array_merge($this->params,$element->relation->params);
else
$this->params=$element->relation->params;
}
$this->elements[$element->id]=true;
}
Joins with another join element
Signup or Login in order to comment.