0

我正在使用可包含的行为,我的 find('all') 的结果是:

array(
    (int) 0 => array(
        'User' => array(
            'id' => '106',
            'email' => 'daje@daje.it',
            'pwd' => '0433c024cb08be13000d59a347e640482843f46f177e95749dc6599c259617fd3491dcb940b47693cbbc7f65a2cc5ef62deca2e600c1be133ad54170f7d1fbd1',
            'role_id' => '3',
            'active' => '1'
        ),
        'Lead' => array(
            'id' => '6'
        ),
        'Estimate' => array(
            (int) 0 => array(
                'lead_id' => '6',
                'Estimate' => array(
                    (int) 0 => array(
                        'TOT_count' => '2'
                    )
                )
            )
        )
    )
)

我需要计算领先的估计数。

总数(2)是正确的,但我看到嵌套的“估计”数组,为什么?

我想得到的结果是:

array(
    (int) 0 => array(
        'User' => array(
            'id' => '106',
            'email' => 'daje@daje.it',
            'pwd' => '0433c024cb08be13000d59a347e640482843f46f177e95749dc6599c259617fd3491dcb940b47693cbbc7f65a2cc5ef62deca2e600c1be133ad54170f7d1fbd1',
            'role_id' => '3',
            'active' => '1'
        ),
        'Lead' => array(
            'id' => '6'
        ),
        'Estimate' => array(
          'TOT_count' => '2'
        )
    )
)

这是发现:

$options = array(
                    'contain' => array(
                        'User',
                        'Estimate' => array(
                            'fields' => 'COUNT(*) AS TOT_count'                             
                        )   
                    ),
                    'conditions' => array('Lead.id' => 6),
                    'fields' => 'User.*',                           
                    'limit' => 1

                );

    debug($this->Lead->find('all', $options));

我该怎么做?谢谢!

4

1 回答 1

3

当您使用“自定义”AS语句时,在您的情况下TOT_count,Cake 将始终将其放在名为0. TOT_count您可以通过在模型中定义为virtualField来避免这种情况。这样,它将直接嵌套在结果集中的模型名称下。

其次,它lead_id被强制检索,因为它是“需要”与Lead模型进行连接的。如果没有那条信息,它就无法正确检索所有数据。

于 2013-01-09T20:58:54.533 回答