2012-10-28 15 views
5

In ZF1 ha funzionato in questo modo:Zend Framework 2: sql subquery

$selectColumns = array(
    '*', 
    'orders_total' => "(".$db->select()->from("orders", array("COUNT(*)"))->where("orders.parent_id=mytable.id").")", 
); 
$select = $db->select()->from('mytable', $selectColumns); 

Come fare questo in ZF2? Grazie.

risposta

7

Si prega di provare questo.

$sql = new Sql($this->_adapter); 
$mainSelect = $sql->select()->from('mytable'); 
$subQry = $sql->select() 
     ->from('orders') 
     ->columns(array('orderCount' => new \Zend\Db\Sql\Expression('COUNT(orders.id)'))); 
$mainSelect->columns(
     array(
      'id', 
      'orders_total' => new \Zend\Db\Sql\Expression('?', array($subQry)), 
     ) 
); 

$statement = $sql->prepareStatementForSqlObject($mainSelect); 
$comments = $statement->execute(); 
$resultSet = new ResultSet(); 
$resultSet->initialize($comments); 

return $resultSet->toArray(); 

Link: ZF2 - subqueries

0

Senza ulteriori informazioni si potrebbe provare:

$selectColumns = array(
    '*', 
    'orders_total' => "(".$db->select()->from("orders", array("COUNT(*)"))->where("orders.parent_id", "mytable.id").")", 
); 
$select = $db->select()->from('mytable', $selectColumns); 

Sarà necessario aggiungere in alto con le istruzioni d'uso:

use Zend\Db\Sql\Select; 
use Zend\Db\Sql\Where; 
1

si può provare questo:

// Make your query here using the builder if you wish, 
// but we will need to convert to string for the Expression 
$sub = new Select('orders'); 
$sub->columns(array(new Expression('COUNT(*) as total'))) 
    ->where(array('id' => 4)) 
; 
// You could just create an expression.. 
$subquery = new \Zend\Db\Sql\Expression("({$sub->getSqlString()})"); 

$select = new \Zend\Db\Sql\select('tablename'); // this is inside a 

$select->columns(array('*', 'orders_total' => $subquery)); 

l'output sarà simile a questo:

SELECT 
    .*, 
    (SELECT COUNT(*) as total FROM "orders" WHERE "id" = '4') AS orders_total 
FROM tablename 

Non ho trovato un modo piacevole di utilizzare il generatore di query per eseguire questo tipo di query senza dover utilizzare query non elaborate.

0

Si può provare ristrutturazione SQL a qualcosa di simile:

SELECT 
    *, 
    SUM(IF(O.parent_id IS NULL, 0, 1)) AS orders_total 
FROM mytable 
    LEFT JOIN orders O ON mytable.id = O.parent_id 

Che si può rappresentare utilizzando Zend Framework 2 come:

$select = new Select('mytable'); 
$select->columns(array(
    '*', 
    'orders_total' => new Expression("SUM(IF(O.parent_id IS NULL, 0, 1))") 
)); 
$select->join(array('O', 'orders'), 
       "mytable.id = O.parent_id", 
       Select::JOIN_LEFT); 
$select->group(array('mytable.id')); 

$result = $dbh->selectWith($select); 

Assumendo $ dbh è la tua scheda di database.