Zend选择所有列

7 php zend-framework zend-db

在以下代码中:


$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);
Run Code Online (Sandbox Code Playgroud)

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

我怎样才能选择一些?

Bil*_*win 8

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

->join('user_details', 'user_id.uid = user_details.uid')
Run Code Online (Sandbox Code Playgroud)

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

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

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

->join('user_details', 'user_id.uid = user_details.uid', array())
Run Code Online (Sandbox Code Playgroud)

您在from()通话中添加的限定列应该仍然存在.要自己验证,请打印SQL:

print $result . "\n"; // calls __toString() method on Zend_Db_Select object
Run Code Online (Sandbox Code Playgroud)


Jam*_*ore 6

最后在连接中添加另一个参数 - 一个空数组.这将告诉它从连接中选择没有列.使用现在的代码,您将从连接表中选择所有列.

->join('user_details', 'user_id.uid = user_details.uid', array())
Run Code Online (Sandbox Code Playgroud)