php - 如何将 ZF ->joinLeft()s 变成子查询?

标签 php zend-framework join subquery zend-db

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

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

最佳答案

你可以使用

$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()) );

关于php - 如何将 ZF ->joinLeft()s 变成子查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16335241/

相关文章:

php - 从多个表检索 mysql 数据到一个 php 页面

php - 在数据库 php-jquery 中添加新记录时的通知

mysql - 具有相互连接的多个表连接的 SQL 查询

sql - 在调试 SQL 查询时需要帮助

php - 代码点火器 : losing session data after login

php - 从 mysql 数据库获取日期数组?

php - 设置 Zend Soap 客户端内容类型

php - Zend Studio 9 中没有 PHP 函数类型等

zend-framework - 如何在 zf2 中使用辅助类?

sql - 在 Oracle 中添加冗余连接条件会导致不同的计划