php – Zend选择所有列

在以下代码中:
$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选择表中的所有列,而不仅仅是请求的列.

我怎样才能选择一些?

问题出在你的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

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...