7

在以下代码中:


$selectColumns= array('user_id.user_email', // inner join the data from user_id and user_details
                            'user_details.first_name', 
                            'user_details.last_name');
        $result = $handle->select()->from('user_id', $selectColumns)
                                   ->where('user_id.uid=?', $uid)
                                   ->join('user_details', 'user_id.uid = user_details.uid')
                                   ->query(ZEND_DB::FETCH_OBJ);

Zend 选择表中的所有列,而不仅仅是请求的列。

我怎样才能只选择一些?

4

2 回答 2

8

问题出在您的join()方法调用中:

->join('user_details', 'user_id.uid = user_details.uid')

可选的第三个参数是表中的列。如果参数不存在,则默认为user_details.*

请注意,您从表中的两个表中添加了限定列from(),但这对默认值没有影响user_details.*。抱歉,Zend_Db_Select只是不够聪明,无法跟踪所有这些。

您可以join()通过传递一个空数组来使调用不添加任何列:

->join('user_details', 'user_id.uid = user_details.uid', array())

您在调用中添加的限定列from()应该仍然存在。要自己验证这一点,请打印 SQL:

print $result . "\n"; // calls __toString() method on Zend_Db_Select object
于 2009-06-23T17:01:28.040 回答
6

最后将另一个参数添加到您的连接 - 一个空数组。这将告诉它不要从连接中选择任何列。使用您现在拥有的代码,您可以从连接表中选择所有列。

->join('user_details', 'user_id.uid = user_details.uid', array())
于 2009-06-23T17:01:10.427 回答