2009年12月6日日曜日

rails、 ActiveRecordについて(多対多)

find メソッドにより,関連テーブルを取ってきたい。(階層的に)

ちなみに

student
↑(1)

↑(N)
rishu
↓(N)

↓(1) 
syllabus

すなわち、

student
↑(N)

↓(N)
syllabus

という関係。


まず、宣言として、
-----
#rishu.rb

class Rishu < through ="">:rishus
end
-----
#syllabus.rb

class Syllabus < through =""> :rishus
end
-----

このようにする。

controller にて

@rishu_classes = Student.find(:all,:conditions => ['student_ID = ?','xxxx'],:include => {:rishus => :syllabus})

とし、変数に格納し、
viewにて

<% @rishu_classes[0].rishus.each do |rishu| %>
<%=rishu.syllabus.class_NAME%>
<% end %>

とした。

ここで、2行目の部分は、
       (rishu.syllabus.class_NAME)
student[0].rishu[0].syllabus.class_NAME
           [1].syllabus.class_NAME
            ・
            ・
            ・
という感じ。
つまり、"student"配列の要素0→"rishu"それぞれのハッシュをeach→"syllabus.class_NAME"を呼び出すというようになっている。

ここで、最後に出たエラー

-----

NoMethodError in Juko#show

Showing app/views/juko/show.html.erb where line #9 raised:

You have a nil object when you didn't expect it!
The error occurred while evaluating nil.class_NAME

-----

意味が分からないが、結局は、

rishus のテーブルにおいて、

rishu1:
student_id: 2053932785
syllabus_id: 153075031

と決めていたidが間違っていて対応していなかっただけだった。


しかもidは定義できるという・・・・

0 件のコメント:

コメントを投稿