標籤:
在閱讀的過程中有不論什麼問題,歡迎一起交流
郵箱:[email protected]
QQ:1494713801
一、怎樣定義關聯
兩個model之間經常會存在關聯關係,為瞭解決這些關聯引起的複雜操作問題,能夠在model定義時定義其關聯關係。如:實體customers和orders定義例如以下:
class Customer < ActiveRecord::Base has_many :orders , dependent: :destroy end class Order < ActiveRecord::Base belongs_to :customer end |
二、關聯的類型
belongs_to
has_one
has_many
has_many :through
has_one :through
has_and_belongs_to_many
1、belongs_to(與has_many相應)
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMDUxNTc2MQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" width="368" height="145">
2、has_one
3、has_many(與belongs_to相應)
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMDUxNTc2MQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" width="335" height="145">
4、has_many :through 指many-to-many關聯,定義的實體通過第三方實體與還有一個實體有0或多個關聯(第三方實體與二者都是belongs_to的關係)。
如:病i人預約醫生的範例,每一個預約都相應一個醫生和一個病人。可是通過預約醫生和病人會有多對多的關係。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMDUxNTc2MQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" width="324" height="148">
5、has_one :through 指one-to-one關聯,類似於傳遞依賴,定義的實體通過第三方實體與還有一個實體有一對一的關聯。如:每個suppliers都有一個accounts,而每個accounts相應一個account_histories。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMDUxNTc2MQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" width="339" height="142">
6、The has_and_belongs_to_many Association 指不須要第三方介入的many-to-many關聯。如:組件與部分,每一個組件包含多個部分,而每一個部分又屬於多個組件。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMDUxNTc2MQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" width="332" height="101">
三、關聯的選項
:as
:autosave
:class_name
:dependent
:foreign_key
:inverse_of
:primary_key
:source
:source_type
:through
:validate
1、as:指明為多態關聯 2、autosave:若設為true。當owner實體做出某一操作時會自己主動儲存或刪除其關聯實體的對應操作。 3、class_name:關聯的實體名不能找到相應的實體,通過該屬性設定實際的實體。 4、dependent:當owner實體被摧毀時,關聯實體的行為: destroy:全部關聯實體被摧毀 delete_all:全部關聯實體被直接從資料庫刪除,不可恢複 nullify:外鍵被設為null,不可恢複 restrict_with_exception:拋出異常提示 restrict_with_error:拋出錯誤提示 5、foreign_key:定義外鍵的列名 6、inverse_of:指明反向關聯的實體 7、primary_key:指明關聯項的id 8、through:指明多對多的關係使用的第三方實體 9、validate:假設設為false,關聯關係將會無效。
【Ruby】Ruby的model學習——Active Record Associations