我不知道如何使用.where()检索关联模型数据的方法。在此示例中,项目belongs_to用户...classProjectparams[:id]}).firstendend在App/views/projects/invite.html.erg返回:---!ruby/object:Projectattributes:id:22name:SomeProjectNamebelongs_to:1instructions:Blablablaactive:truemax_duration:2max_videos:created_at:2013-08-2615:56:50.000000000Zu
使用select_date返回一个params[:my_date]和year,month和day属性。如何轻松获取Date对象?我希望得到像params[:my_date].to_date这样的东西。我也很乐意使用date_select。 最佳答案 使用date_select分别为日、月和年提供3个独立的键/值对。因此,您可以将它们作为参数传递到Date.new中以创建新的Date对象。Event模型的date_select返回参数示例:"event"=>{"name"=>"Birthday","date(1i)"=>"2012",
我在erb中有一个编辑表单。在代码中我有一个带有选项的选择::gender)%>但是,选择没有显示正确的选择值。我做错了什么?如果我对其进行硬编码,我可以让它工作,但这当然不是一个可行的选择。 最佳答案 在您的代码中,您的options_for_select()调用将所选值设置为“性别”,并且不会尝试使用表单对象中的值。请参阅options_for_select()的文档用于使用示例。options_for_select(['Mare','Stallion','Gelding'],f.object.gender)options_fo
如何做一个有条件的where子句?我有一个运行查询的rake任务。假设我正在构建这样的查询:residentials=Residential.where(:is_active=>true)现在,如果我将某个参数传递给rake任务,我想添加到where子句中。我在想这样的事情:residentials.where(:something_else=>true)ifparam_was_passed但这只是替换了现有的where子句。如何将它添加到现有的where子句中? 最佳答案 可以链接where语句residentials=Resid
这两个语句给我相同的结果:[1,2,3,4].find_all{|x|x.even?}[1,2,3,4].select{|x|x.even?}find_all只是一个别名吗?有理由使用一个而不是另一个吗? 最佳答案 #find_all和#select非常相似;差异非常微妙。在大多数情况下,它们是等价的。这取决于实现它的类。Enumerable#find_all和Enumerable#select在同一代码上运行。Array和Range也是如此,因为它们使用Enumerable实现。在Hash的情况下,#select被重新定义为返回一
是否可以在select_tag方法中添加类似:include_blank=>'PleaseSelect'的选项,就像使用select方法?好像不行。select_tag方法有什么替代方法吗? 最佳答案 在Rails3中,select_tag有一个:prompt选项:select_tag"things",many_thing_as_options,:prompt=>"Pleaseselect" 关于ruby-on-rails-我可以在select_tag中包含空白字段吗?,我们在Stack
collection_select和selectRails助手:我应该使用哪一个?我看不出这两种方式有什么不同。两个助手都获取一个集合并在select标签内生成options标签。是否存在collection_select优于select的场景?或者我在这里缺少什么? 最佳答案 collection_select旨在在项目列表是ActiveRecord对象数组时使用。collection_select构建在select之上,因此当您需要显示对象集合而不是字符串数组时,它是一种方便的方法。collection_select(:post
这可能是一个简单的问题,但我似乎正在努力寻找一个优雅的解决方案。我有两个ActiveRecord模型类,它们之间有has_one和belongs_to关联:classItem我正在寻找一种优雅的方法来查找所有Item对象,这些对象没有与之关联的购买对象,理想情况下无需求助于boolis_purchased或Item上的类似属性。现在我有:purchases=Purchase.allItem.where('idnotin(?)',purchases.map(&:item_id))这行得通,但对我来说似乎效率低下,因为它执行两个查询(并且购买可能是一个庞大的记录集)。运行Rails3.1.
ActionView::Template::Error(PG::Error:ERROR:forSELECTDISTINCT,ORDERBYexpressionsmustappearinselectlist我正在创建一个事件网站,我正在尝试按事件的开始时间对呈现的rsvps进行排序。有很多RSVPS,所以我将它们分组为不同的,但在过去的几天里,我在排序结果时遇到了很多困难,而没有在PG上弹出这个错误。我已经查看了之前关于该主题的一些问题,但仍然很迷茫。我怎样才能让它工作?非常感谢!@rsvps=Rsvp.where(:voter_id=>current_user.following.co
在Rails中,find_each和where用于从ActiveRecord支持的数据库中检索数据。您可以将查询条件传递给where,例如:c=Category.where(:name=>'Ruby',:position=>1)并且您可以将批量大小传递给find_each,例如:Hedgehog.find_each(batch_size:50).map{|p|p.to_json}但是下面两段代码有什么区别呢?#code1Person.where("age>21").find_each(batch_size:50)do|person|#processingend#code2Person.