2

関連する個別のモデル エントリのみを選択しようとしていますが、うまくいかないようです。

私はこれを持っています:

$active_questions = $this->Question->find('all', array('conditions' => array('test_id' => $active_tests), 'fields' => array('answer_style_id'), 'contain' => array(
        'Answer' => array(
            'fields' => array('capital_category_id'),
            'CapitalCategory' => array(
                'fields' => array('id', 'DISTINCT capital_id', 'DISTINCT category_id', 'delete_flag'),
                'Capital' => array(
                    'fields' => array('id', 'delete_flag')
                ),
                'Category' => array(
                    'fields' => array('id', 'delete_flag')
                )
            )
        )
    )));

しかし、DISTINCT キーワードで指定した場合でも、Cake は関連付けられたモデル キーを自動的に追加するようです。

Query: SELECT `CapitalCategory`.`id`, DISTINCT `CapitalCategory`.`capital_id`, DISTINCT `CapitalCategory`.`category_id`, `CapitalCategory`.`delete_flag`, `CapitalCategory`.`capital_id`, `CapitalCategory`.`category_id` FROM `capital_categories` AS `CapitalCategory`   WHERE `CapitalCategory`.`id` = 217  

DISTINCT の大文字またはカテゴリのみを除外するにはどうすればよいですか? 現在の例では、Cake は同じ ID を持つ 20 のカテゴリを返します。1つだけ返してほしい。

ありがとうございました。

4

2 に答える 2

0

'group'を'fields'のすぐ下に置き、'contain'の中に入れないのはなぜですか。また、'fields'を完全に削除する必要があるかもしれません。

于 2011-07-28T02:34:26.580 に答える
0

私の頭の上から、「グループ」オプションを使用して次のことが機能する可能性があります

$active_questions = $this->Question->find(
  'all', 
  array(
    'conditions' => array('Question.test_id' => $active_tests), 
    'fields' => array('answer_style_id'), 
    'contain' => array(
      'Answer' => array(
        'fields' => array('capital_category_id'),
        'CapitalCategory' => array(
          'fields' => array('id', 'capital_id', 'category_id', 'delete_flag'),
          'group' => array('capital_id', 'category_id'),
          'Capital' => array(
            'fields' => array('id', 'delete_flag')
          ),
          'Category' => array(
            'fields' => array('id', 'delete_flag')
          )
        )
      )
    )
  )
);
于 2011-05-13T18:20:40.230 に答える