人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

CakePHP1.2
モデルのアソシエーションについて。
以下のような3つのテーブルがあるとき

1.所有物一覧情報テーブル(
id
user_id
item_id
quantity(数量)
)

2.アイテムテーブル(
id
item_name
item_size
maker_id
)

3.メーカーテーブル(
id
maker_name
)

user_idから所有物一覧情報を探しにいってmaker_nameまで取得できるようにアソシエーションを設定したいのですが可能でしょうか。
belongsToを親子関係にする方法はわかるのですが、孫要素まで設定する方法がわかりません。

●質問者: dedara
●カテゴリ:コンピュータ ウェブ制作
✍キーワード:アイテム アソシエーション メーカー モデル
○ 状態 :終了
└ 回答数 : 1/1件

▽最新の回答へ

1 ● t_shiono
●200ポイント ベストアンサー

Modelのrecursiveの指定では駄目なのでしょうか?

User, Item, Makerのモデルがあり、

User hasAndBelongsTo Item

Item hasAndBelongsTo User

Item belongsTo Maker

Maker hasMany Item

というアソシエーションを与えておけば、

コントローラ内で、

$this->User->findAll(array('id' => ユーザID), null, null, null, null, 2);

とすれば、メーカー名まで取得できます。

◎質問者からの返答

recursiveというものを知りませんでした。

うまくいきそうなので試してみます

ありがとうございました


【追記】

わからない点がいろいろ出てきたのでコメント欄に書きました

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ