在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.
在Rails3.0.3上的Ruby1.9.2中,我试图测试两个Friend之间的对象相等性(类继承来自ActiveRecord::Base)对象。对象相等,但测试失败:Failure/Error:Friend.new(name:'Bob').shouldeql(Friend.new(name:'Bob'))expected#got#(comparedusingeql?)只是为了笑,我还测试了对象身份,正如我预期的那样失败了:Failure/Error:Friend.new(name:'Bob').shouldequal(Friend.new(name:'Bob'))expected#=
在Ruby中取消定义方法非常简单,我可以使用undefMETHOD_NAME。类有类似的东西吗?我正在使用MRI1.9.2。我必须取消定义ActiveRecord模型,运行两行代码,然后将模型恢复为原始形式。问题是,我有一个模型Contact,我正在使用公司的API,碰巧他们有一些名为Contact的类,更改我的模型名称会对我来说是很多工作。遇到这种情况我该怎么办? 最佳答案 classFoo;end#=>nilObject.constants.include?(:Foo)#=>trueObject.send(:remove_con
我有2个模型。Report和Server有belongs_to和has_many关系。我使用delegate创建了一个访问器方法允许Report找到其关联的Server.company_id.现在,我想查询Report这让我可以找到所有Report与特定的Server相关联具有特定的company_id属性5.这是我的两个模型。是的,我知道自Report以来当前查询将无法正常工作。没有属性company_id.不,我不想存储company_idReport内部因为该信息不属于Report.举报classReport:serverclass服务器classServer
对于普通列,您可以通过columns类方法获取它们。但是,如果在关系方法中设置了foreign_key选项,关联的名称可能会完全不同。例如,给定classPosthas_many:comments,:foreign_key=>:message_id#thisisacontrivedexampleend如果我做了Post.column_names,我可以得到message_id,但是有什么方法可以得到comments吗? 最佳答案 Model.reflections提供有关模型关联的信息。它是一个以关联名称为关键字的Hash。例如Po
我有一个小的ruby脚本,我想在其中使用ActiveRecord轻松访问数据库模型。最好的方法是什么? 最佳答案 require'active_record'#ChangethefollowingtoreflectyourdatabasesettingsActiveRecord::Base.establish_connection(adapter:'mysql2',#or'postgresql'or'sqlite3'or'oracle_enhanced'host:'localhost',database:'your_databa
如何使用逻辑OR而不是AND来组合2个不同的条件?注意:2个条件是作为rails范围生成的,不能轻易地直接更改为where("xory")之类的内容。简单的例子:admins=User.where(:kind=>:admin)authors=User.where(:kind=>:author)很容易应用AND条件(对于这种特殊情况是没有意义的):(admins.mergeauthors).to_sql#=>select...from...wherekind='admin'ANDkind='author'但是您如何生成具有2个不同Arel关系的以下查询?#=>select...from.
据我了解,super关键字在当前类的父类(superclass)中调用与当前方法同名的方法。下面的autoload方法中,调用了super。我想知道在哪个父类(superclass)中我会找到一个具有相同名称的方法,或者对super的调用在这里做什么moduleActiveSupportmoduleAutoload...defautoload(const_name,path=@@at_path)full=[self.name,@@under_path,const_name.to_s,path].compact.join("::")location=path||Inflector.und
我觉得这应该很简单,但是我的脑子短路了。如果我有一个代表当前用户的对象,并且想查询除当前用户之外的所有用户,考虑到当前用户有时可能为nil,我该怎么做?这就是我现在正在做的:defindex@users=User.all@users.deletecurrent_userend我不喜欢的是我正在对查询结果进行后处理。除了感觉有点不对之外,如果我将查询转换为使用will_paginate运行,我认为这不会很好地工作。关于如何通过查询执行此操作的任何建议?谢谢。 最佳答案 可以在Rails4及更高版本中执行以下操作:User.where.
我正在创建一堆迁移,其中一些是标准的“创建表”或“修改表”迁移,其中一些修改数据。我正在使用我实际的ActiveRecord模型来修改数据,ala:Blog.all.eachdo|blog|update_some_blog_attributes_to_match_new_schemaend问题是,如果我加载Blog类,然后修改表,然后再次使用Blog类,模型具有旧表定义,并且无法保存到新表。有没有办法重新加载类及其属性定义以便我可以重用它们? 最佳答案 答案是肯定的!Blog.reset_column_information