【发布时间】:2010-08-05 22:05:37
【问题描述】:
我要生成如下 SQL:
SELECT `rc`.*, `c`.`name` FROM `RunConfigurations` AS `rc` INNER JOIN `Clients` AS `c` ON rc.client_id = c.id WHERE (rc.client_id = ?) ORDER BY `rc`.`config_name` ASC
但是我得到了:
SELECT `rc`.*, `c`.* FROM `RunConfigurations` AS `rc` INNER JOIN `Clients` AS `c` ON rc.client_id = c.id WHERE (rc.client_id = ?) ORDER BY `rc`.`config_name` ASC
不同的是我想要c.name,而不是c.*
使用以下 ZF PHP 代码:
public function fetchConfigurations($clientId = null, $order = 'rc.config_name ASC')
{
$db = $this->getDb();
$stmt = $db->select()
->from(array('rc' => 'RunConfigurations','c.name'))
->join(array('c' => 'Clients'),'rc.client_id = c.id')
->order($order);
if(is_numeric($clientId))
{
$stmt->where('rc.client_id = ?')
->bind(array($clientId));
}
$results = $db->fetchAll($stmt);
if(sizeof($results) > 0)
{
$configs = array();
foreach($results as $row)
{
$configs[] = $this->createRunConfigurationFromRow($row);
}
return $configs;
}
else
{
die($stmt->__toString());
return null;
}
}
这很令人恼火,我觉得我在任何一个方面都遗漏了一些东西:
->from(array('rc' => 'RunConfigurations','c.name'))
或
->join(array('c' => 'Clients'),'rc.client_id = c.id')
ZF 的例子并没有说明这一点。
【问题讨论】:
标签: php zend-framework zend-db zend-db-table zend-db-select