私はこのようなモデル関係を持っています:
Person belongsTo Counselor, PersonType, Program, Term
Person hasMany PersonStage, Text, Mail
PersonStage belongsTo Person, Stage
Stage hasMany PersonStage
基本的に、stage と person の間に多対多の関係を作成しましたが、PeronStage テーブル(people_stages)
にはいくつかの追加情報、最も重要なcreated
フィールドがあります。
私がやろうとしているのは、多くの場合、Person の現在のPersonStage に基づいて、結果を見つけてページ付けすることです。これは常に最新 ( MAX(people_stages.created)
.)
Cakeでこれを達成する方法がわかりません。SQL では結合クエリが次のようになることはわかっていますが、これを Cake で複製する方法がわかりません。
SELECT *
FROM people AS p LEFT JOIN (people_stages AS s NATURAL JOIN (
SELECT person_id, MAX(created) created
FROM people_stages
GROUP BY person_id
) t) ON s.person_id = p.id
ORDER BY p.last_name
私はさまざまな結合を試みましたが、すべて役に立ちませんでした。これらの結合のない私のコードは次のとおりです。
$this->Paginator->settings = array(
'recursive' => -1,
'contain' => array('Counselor','Term','Program','PersonType'),
'fields' => array('Person.*', 'Counselor.id', 'Counselor.first_name', 'Counselor.last_name', 'Term.*', 'Program.*', 'PersonType.*'),
'order' => array('Person.counselor_read' => 'asc', 'PersonStage.create' => 'desc'),
'limit' => 25
);
$people = $this->Paginator->paginate('Person');