在以下代码中:
$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选择所有表格中的列,而不仅仅是所请求的列。
我如何只选择一些?
答案 0 :(得分:6)
在结尾添加另一个参数 - 一个空数组。这将告诉它从连接中选择没有列。使用现在的代码,您将从连接表中选择所有列。
->join('user_details', 'user_id.uid = user_details.uid', array())
答案 1 :(得分:6)
问题出在您的join()
方法调用中:
->join('user_details', 'user_id.uid = user_details.uid')
可选的第三个参数是 this 表中的列。如果参数不存在,则默认为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