如何将ZF - > joinLeft()转换为子查询?

时间:2013-05-02 10:01:51

标签: php zend-framework join subquery zend-db

如何将以下查询转换为子查询? 我不想使用JOINS我想通过子查询做同样的事情。 i-e 我需要三个连接中的三个子查询。下面的查询怎么可能?

protected $_name = 'sale_package_features';
public function getAllSalePackageFeatures(){
    $sql = $this->select()->setIntegrityCheck(false)
            ->from(array('spf' => $this->_name))
            ->joinLeft(array('sd' => 'sale_devices'),'sd.sale_device_id = spf.sale_device_id',array('sd.sale_device_name AS deviceName'))
            ->joinLeft(array('sp' => 'sale_packages'),'sp.sale_package_id = spf.sale_package_id',array('sp.sale_package_name AS packageName'))
            ->joinLeft(array('sf' => 'sale_features'),'sf.sale_feature_id = spf.sale_feature_id',array('sf.sale_feature_name AS featureName'))
            ->where('sf.parent_id != ?',0)
            ->order('spf.sale_package_feature_id ASC');
    return $sql->query()->fetchAll();
}

编辑:

SELECT
   `spf`.*, `sd`.`sale_device_name` AS `deviceName`, 
   `sp`.`sale_package_name` AS `packageName`, 
   `sf`.`sale_feature_name` AS `featureName` 
FROM `sale_package_features` AS `spf` 
LEFT JOIN `sale_devices` AS `sd` 
  ON sd.sale_device_id = spf.sale_device_id
LEFT JOIN `sale_packages` AS `sp` 
  ON sp.sale_package_id = spf.sale_package_id 
LEFT JOIN `sale_features` AS `sf` 
  ON sf.sale_feature_id = spf.sale_feature_id 
WHERE (sf.parent_id != 0) 
ORDER BY `spf`.`sale_package_feature_id` ASC

1 个答案:

答案 0 :(得分:0)

你可以使用

$dbAdapter = Zend_Db_Table::getDefaultAdapter();
$subSelect = $dbAdapter
    ->select()
    ->from( 'tablename',
        array(
            'col1_alias' => 'column1_name',
            'col2_alias' => 'column2_name',
        ))
    ->where('somefield = ?', $value_to_be_quoted);

$select = $dbAdapter
    ->select()
    ->from(array('sub_alias' => $subSelect ))
    ->where('otherfield = ?', $other_value_to_be_quoted);

$sql = $select->assemble();

$sql将包含

SELECT 
    sub_alias . *
FROM
    (SELECT 
        tablename.column1_name AS col1_alias,
            tablename.column2_name AS col2_alias
    FROM
        tablename
    WHERE
        (somefield = 'quoted_value')) AS sub_alias
WHERE
    (otherfield = 'quoted_other_value')

如果您需要使用SELECT .. WHERE x IN (subselect)而不是

$select->where( 'column IN (?)', new Zend_Db_Expr($subselect->assemble()) );