草庐IT

has_data

全部标签

ruby-on-rails - Rails 4 迁移 : has_and_belongs_to_many table name

我目前正在尝试将Rails3.2应用程序切换到Rails4.0。但是我对has_and_belongs_many模型有一个问题。我创建了一个测试应用程序,但我遇到了同样的问题。这就是我所做的:创建了两个模型:foo_clip和foo_urlclassFooClip在此之后我更新了迁移文件:classCreateFooClips现在我已经为has_and_belongs_to_many表创建了迁移文件classCreateFooClipsFooUrls作为最后一步,我创建了一个用于测试的种子文件:foourl1=FooUrl.create!(:url=>'http://www.googl

ruby-on-rails - counter_cache 与 has_many :through

我刚刚创建了一个counter_cache字段,Controller看起来像这样。@users=User.where(:sex=>2).order('received_likes_count')User.rb中的关联是has_many:received_likes,:through=>:attachments,:source=>:likes,:dependent=>:destroy问题是counter_cache是在Like.rb的belong_to中声明的,我不知道如何告诉它它是用于has_many:through关联。belongs_to:user,:counter_cache=>

ruby - Rails has_and_belongs_to_many & has_many :through scaffolding

有没有办法为具有has_and_belongs_to_many或has_many:through关系的Rails模型生成脚手架?如果没有,是否存在未包含此功能的某些基本形式的开发原因?Rails要求开发人员生成和编辑一个“自定义”“连接表迁移”。对细节的必要关注是一种提醒Rails开发人员一些重要事实的方式,还是这仅仅是Rails如何“进行中的工作”的一个例子?Stackoverflow快速搜索:"has_and_belongs_to_many"yields821questions"has_many:through"yields933questions...其中许多都以“我如何...”

ruby-on-rails - 为具有 has_many 关系的俄罗斯娃娃缓存构建 Rails 应用程序

在研究了DHH和其他关于基于键的缓存过期和俄罗斯套娃缓存的博客文章之后,我仍然不确定如何处理一种关系类型。具体来说,has_many关系。我将分享我对示例应用程序的研究结果。这有点讲故事,所以等一下。假设我们有以下ActiveRecord模型。我们只关心模型的cache_key的适当更改,对吗?classArticle我们已经有一篇文章,有一条评论。两者都是不同的作者。目标是在以下情况下更改文章的cache_key:文章正文或标题更改其评论的正文发生变化文章作者姓名变更文章评论作者姓名变更所以默认情况下,我们适用于情况1和情况2。1.9.3-p194:034>article.cache

ruby-on-rails - rails 中的嵌套表单 - 在 has_many 关系中访问属性

我有一个用户和一个配置文件模型。一个用户可以拥有多个配置文件。在用户创建过程中,我只需要从我的用户模型中的配置文件部分(即电话号码)访问一个信息。因此,我试图通过attr_accessible完成它.我的user.rb看起来像这样。has_many:profilesattr_accessible:handle,:email,:password,:profile_mobile_numberattr_accessor::profile_mobile_number我面临的问题是,当我尝试在user.rb中的一个方法中调用getter方法profile_mobile_number(该方法是私有

ruby-on-rails - 如何在数据库中反射(reflect) Ruby on Rails 中新的 belongs_to 和 has_many 关系

我是Rails的新手(通常是Python专家),只是为了好玩而尝试构建一个简单的任务管理器应用程序。我正在使用Devise进行身份验证,并且有一个我试图与用户关联的任务对象。我已将以下内容添加到任务模型中:classTask并且我在我的Devise用户模型中添加了以下内容:classUser>end每当我添加此信息时,我都会运行:rakedb:migrate。然后它给了我一个错误,当我试图用它做任何事情时,user_id的数据库字段不存在。我确信这是我所缺少的相当简单的东西。感谢您的帮助。 最佳答案 向模型添加belongs_to(

ruby-on-rails - Rails 模型 has_many , belongs_to 关系

我有两个模型classUser我需要在Product表中添加一列user_id还是Rails默认添加它? 最佳答案 您需要手动将user_id列添加到Product模型。如果您尚未创建模型,请将列列表中的引用添加到模型生成器。例如:rails生成模型Productname:stringprice:decimaluser:references或者,如果您的Product模型已经存在,您需要做的是:railsgmigrationaddUserIdToProductsuser_id:integer这将生成一个迁移,将user_id列正确添

ruby-on-rails - 脚手架 ActiveRecord : two columns of the same data type

另一个基本的Rails问题:我有一个数据库表,需要包含对特定数据类型的两个不同记录的引用。假设示例:我正在制作视频游戏数据库。我有一张“公司”表。我想为每个“视频游戏”条目指定一个开发者和一个发布者。我知道如果我想拥有一家公司,我可以这样做:script/generateVideogamecompany:references但我需要同时拥有这两家公司。我宁愿不使用连接表,因为给定的数据类型只能有两个,我需要它们是不同的。看起来答案应该很明显了,但是我在网上到处都找不到。 最佳答案 只是为了稍微整理一下,在您的迁移中,您现在还可以:c

ruby-on-rails - 一个 has_many :through Relationship 的 Rails RSpec 测试

我是测试和Rails的新手,但我正努力让我的TDD流程正常运行。我想知道您是否使用任何类型的范例来测试has_many:through关系?(或者我想一般来说只是has_many)。例如,我发现在我的模型规范中,我肯定会编写简单的测试来检查关系两端的相关方法。即:require'spec_helper'describePostdobefore(:each)do@attr={:subject=>"f00PostSubject",:content=>"8arPostBodyContent"}enddescribe"validations"do...enddescribe"categoriz

ruby-on-rails - 附加到 rake db :seed in rails and running it without duplicating data

Rakedb:seed使用应用程序的默认数据库值填充您的数据库,对吗?那么如果您已经有一个种子并且需要添加到它(您添加一个需要种子的新功能)怎么办?根据我的经验,当我再次运行rakedb:seed时,它已经添加了现有内容,因此现有内容变成了两倍。我需要的是添加一些种子,当运行时,它应该只添加最新的种子,而忽略现有的种子。我该怎么做?(我通常采用的肮脏的、菜鸟的方式是截断我的整个数据库然后再次运行种子,但这在生产中不是很聪明,对吧?) 最佳答案 更简洁的方法是使用find_or_create_by,如下所示:User.find_or_