特定のプラットフォームでのそのゲームのレビューを取得するために、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 のレビューが含まれていることです。