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) は正しいのですが、ネストされた 'Estimated' 配列が表示されます。なぜですか?

私が得たい結果は次のとおりです。

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これは、モデルでvirtualFieldTOT_countとして定義することで回避できます。そうすれば、結果セットのモデル名のすぐ下にネストされます。

次に、モデルlead_idと結合するために「必要」であるため、 が強制的に取得されます。Leadそこにその情報がなければ、すべてのデータを適切に取得することはできません。

于 2013-01-09T20:58:54.533 に答える