0

特定のプラットフォームでのそのゲームのレビューを取得するために、Game モデルで find() を呼び出しています。問題は、find() 呼び出しが条件配列に注意を払っていないように見えることです。この呼び出しは、platform_id に関係なく、ゲームのすべてのレビューを返します。

私はこれらのモデルの関連付けを持っています:

  • ユーザーには多くのレビューがあります
  • ゲームには多くのレビューがあります
  • レビューはゲームに属しています
  • 所属するユーザーを確認する
  • ゲーム HABTM プラットフォーム

これは私が作成した検索呼び出しです。

    $options = array(
        'group' => array(
            'Game.id'
        ),
        'joins' => array(
            array(
                'table' => 'reviews',
                'type' => 'LEFT',
                'conditions' => array(
                    'Game.id=reviews.game_id'
                )
            ),
            array(
                'table' => 'platforms',
                'type' => 'LEFT',
                'conditions' => array(
                    'reviews.platform_id=platforms.id'
                )
            ),
            array(
                'table' => 'users',
                'type' => 'LEFT',
                'conditions' => array(
                    'reviews.user_id=users.id'
                )
            )
        ),
        'fields' => array(
            'Game.id', 'Game.name',
            'platforms.id', 'platforms.name',
            'users.id', 'users.username'
        ),
        'conditions' => array(
            'AND' => array(
                'NOT' => array('reviews.review_text' => NULL),
                'platforms.id' => $pid,
            )
        ),
        'limit' => 5
    );

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

platform_id=2 の find() 呼び出しの戻り値の例を次に示します。

array(
(int) 0 => array(
    'Game' => array(
        'id' => '58',
        'name' => 'Bioshock 2'
    ),
    'platforms' => array(
        'id' => '2',
        'name' => 'PlayStation 3'
    ),
    'users' => array(
        'id' => '20',
        'username' => 'pspmaniac'
    ),
    'Review' => array(
        (int) 0 => array(
            'id' => '32',
            'review_text' => 'This is the PC review.',
            'score' => '4',
            'user_id' => '20',
            'game_id' => '58',
            'created' => '2013-04-30 19:59:40',
            'platform_id' => '10'
        ),
        (int) 1 => array(
            'id' => '33',
            'review_text' => 'This is the PS3 review.',
            'score' => '7',
            'user_id' => '20',
            'game_id' => '58',
            'created' => '2013-04-30 20:00:04',
            'platform_id' => '2'
        ),
        (int) 2 => array(
            'id' => '34',
            'review_text' => 'This is the XBOX 360 review.',
            'score' => '6',
            'user_id' => '20',
            'game_id' => '58',
            'created' => '2013-04-30 20:00:22',
            'platform_id' => '1'
        )
    )
)
);

「レビュー」インデックスでは、platform_id=2 のレビューのみを返す必要があるのに、ゲーム (プラットフォーム ID 10、2、および 1) の 3 つのレビューを返します。

これは私のreviewsテーブルです:

CREATE TABLE reviews
(
   id mediumint unsigned not null auto_increment,
   review_text mediumint,
   score int not null,
   user_id mediumint unsigned not null,
   game_id mediumint unsigned not null,
   PRIMARY KEY (id),
   FOREIGN KEY (user_id) REFERENCES users (id),
   FOREIGN KEY (game_id) REFERENCES games (id)
);

結局、返された配列の唯一の問題は、条件「platforms.id=2」だけでなく、すべてのプラットフォーム ID のレビューが含まれていることです。

4

1 に答える 1