在阅读的过程中有不论什么问题,欢迎一起交流

邮箱:[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
【Ruby】Ruby的model学习——Active Record Associations-LMLPHP
 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">【Ruby】Ruby的model学习——Active Record Associations-LMLPHP

 5、has_one :through
   指one-to-one关联,类似于传递依赖,定义的实体通过第三方实体与还有一个实体有一对一的关联。如:每个suppliers都有一个accounts,而每个accounts相应一个account_histories。

【Ruby】Ruby的model学习——Active Record Associations-LMLPHP

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,关联关系将会无效。

          



05-06 03:21