【问题标题】:Zend selects all columnsZend 选择所有列
【发布时间】:2023-04-01 11:45:03
【问题描述】:

在以下代码中:


$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 选择表中的所有列,而不仅仅是请求的列。

我怎样才能只选择一些?

【问题讨论】:

    标签: php zend-framework zend-db


    【解决方案1】:

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

    【讨论】:

      【解决方案2】:

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

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

      【讨论】:

      • +1 表示先到达,+1 表示 Bill 可以获得更多细节。为什么只有 Zend 人投票支持 Zend 人?
      猜你喜欢
      • 1970-01-01
      • 2023-03-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-07-11
      • 2020-05-08
      相关资源
      最近更新 更多