Ruby on Rails belongs_to

belongs_to充实了has_many或has_one协会。

一般来说,foo model belongs_to :bar,如果有一个foo的bar_id外键字段。

这方面的例子:

公司的数据库,其中一个帐户属于一个公司。
论坛制度,凡属于一个专题论坛,这属于一个类别。
画廊制度缩图属于图片。
例如论坛
见ForumExample 。


当使用: counter_cache = true,可以肯定的默认值在您的model_count栏默认的东西,可递增。null+ 1 ,例如,等于null所以bar的SQL将不会工作。

你可以认为此功能将使parent.child.count或parent.child.length使用此缓存,而不是发出新的COUNT个查询。您就错了。

请参阅API的更多信息: counter_cache

另一种方法认为这是说“外键表abc的belongs_to表清晰” 。

Gotchas
留神你的复数与奇异!如果你打算has_many和belongs_to之间,人们很容易混杂在一起的复数形式和singulars 。 belongs_to肯定使用奇异的参数,并不会打印非常方便的错误如果不把正确。

如果您使用的是belongs_to跨越命名空间,你一定会需要使用: class_name和: foreign_key修饰语来belongs_to 。

说你是说你的模型belongs_to供应: : OtherModel

类模型belongs_to : other_model #将无法正常工作,下面的命令将工作belongs_to : other_model , : class_name = “ ”发布时间: : : OtherModel “ : foreign_key = ” “ other_model_id ” endUpdated

Ruby on Rails的has_many
该has_many协会提供了一种方法来存取单程两个表之间的关系。

这方面的例子:

公司的数据库,如某公司可能有多个帐户。
论坛系统,其中一类有很多论坛,其中有许多问题。
例如论坛
见ForumExample 。

又见
belongs_to
has_one
Rails的空气污染指数: has_many
Rails的手册: has_many

该finder_sql选项has_many应该用单引号如果您想要内嵌变量(例如,选择*从哪里user_ID的东西= # (编号) ' )进行评估正确!

你可能感兴趣的:(sql,工作,cache,Ruby,Rails)