1

从数据库中选择数据时,zend 出现问题。在我的查询中,我不想从与另一个表连接的表中选择任何列。我在第三个参数中使用 array() 。但是当我这样做时:

$sql = $db->select();
    $sql->from( "message", "message.message_id" )

        ->->join("network_users","message.network_id = network_users.network_id and message.user_id = network_users.user_id","network_users.network_id") //no get column
        ->join("users","message.user_id = users.user_id",array()) //no get column
        ->where( "message.network_id = :network_id" )
        ->where( "message.del_flg = 0" )
        ->where( "network_users.del_flg = 0" )
        ->where( "users.del_flg = 0" )
        ->order( "message.regist_date DESC" );

 $ary[':network_id']   = $network_id;
 $ret = $db->fetchAll($sql, $ary);

return empty($ret[0]["user_id"]) ? array():$ret;

我总是得到结果是array(0) {}

当我在每个表中获得至少一列时,它会响应正确的结果。

对我的问题有任何想法吗????

谢谢你的帮助。

4

2 回答 2

3

使用null代替array()

所以它看起来像这样: ->join("users","message.user_id = users.user_id",null)

于 2012-06-12T15:14:24.690 回答
0

我发现了问题,问题是我使用return empty($ret[0]["user_id"]) ? array():$ret;而不是return empty($ret[0]["message_id"]) ? array():$ret;.

这就是我总是收到的原因array(0) {}

感谢帮助。^_^

于 2012-06-13T01:54:54.587 回答