草庐IT

ActiveRecord

全部标签

ruby-on-rails - rails ActiveRecord : Multiple conditions in find

这可能更像是一种Ruby语法。我很难在SomeObject.find上获得两个限制条件。分离,条件似乎可行:ifsearch!=''find(:all,:conditions=>['nameLIKE?',"%#{search}%"])elsefind(:all,:conditions=>['active',1]).shuffleend第一个案例我要的是:find(:all,:conditions=>['nameLIKE?',"%#{search}%"],['active',1])但是该行抛出语法错误,意外的')',期待tASSOC。 最佳答案

ruby-on-rails - 删除孤立的父级

我有这样的关系:Parenthas_many:childrenChildbelongs_to:parent我想做的是如果没有更多的child离开,删除parent。所以要做到这一点,我有:Childbefore_destroy:destroy_orphaned_parentdefdestroy_orphaned_parentparent.children.eachdo|c|returnifc!=selfendparent.destroyend这很好用,但是我也想将父级的删除级联到子级。例如。我通常会这样做:Parenthas_many:children,:dependent=>:des

ruby-on-rails - 如何随机化 `ActiveRecord::Relation` 的数组元素位置?

我正在运行RubyonRails3.2.2,我想随机化ActiveRecord::Relation的数组元素位置。我该怎么做? 最佳答案 您总是可以将.order('random()')添加到关系中:ar=Model.where(...).where(...).order('random()')您甚至可以将其添加为范围:classModel有几点需要注意:PostgreSQL和SQLite使用random(),MySQL使用rand(),我不确定其他数据库。ORDERBYrandom()在数据库中可能非常昂贵,因此您不想使用它,除非

ruby-on-rails - 你如何在 rails 中为 "Likes"建模?

我有3个模型:用户、对象、喜欢目前,我有模型:一个用户有很多对象。我如何进行建模:1)一个用户可以喜欢很多对象2)一个对象可以有很多点赞(来自不同的用户)所以我希望能够做这样的事情:User.likes=用户喜欢的对象列表Objects.liked_by=对象喜欢的用户列表下面的模型肯定是错误的...classUser:likesendclassLikes:likesend 最佳答案 为了进一步阐述我对BrandonTilley的回答的评论,我建议如下:classUser:likes,:source=>:thingendclassL

ruby - 是否可以根据单个对象对方法的响应对对象列表进行排序?

我想显示一个产品的画廊,其中包括待售和非待售产品。只是我想让待售的产品出现在列表的前面,而不是待售的对象出现在列表的末尾。我实现此目的的一种简单方法是制作两个列表,然后合并它们(一个列表是on_sale?对象,另一个列表是非on_sale?对象):available_products=[]sold_products=[]@products.eachdo|product|ifproduct.on_sale?available_products...但是对于我现有应用程序的结构来说,由于我的代码中有一个奇怪的地方,这将需要过多的重构(我失去了分页,我宁愿不重构)。如果有一种方法可以通过我的

ruby - 在 RSpec 测试中模拟 ActiveRecord 关系行为

我在测试时遇到过这个问题。假设我有两个模型,User和Post,其中userhas_many:posts。我正在尝试指定包含如下内容的代码块:user=User.find(123)post=user.posts.find(456)我知道如何模拟User.find和user.posts部分。user.posts模拟返回一个Post对象数组。当它到达.find(456)部分时,一切都崩溃了,并出现noblockgiven异常。所以我的问题是:作为user.postsmock的结果我要返回什么,以便.find(456)方法对其起作用?User.first.posts.class说它是Arra

ruby-on-rails - 为什么使用 "self"访问 ActiveRecord/Rails 模型属性?

在我的整个应用程序中,self.没有必要引用用户名。name工作正常。为什么以下代码需要self才能按预期工作?classUser顺便说一句,我知道validates_presence_of可以用来防止保存,但如果没有给出名称,我想使用默认值保存。rails3.0.7。 最佳答案 通常使用self是为了强制Ruby将其识别为方法调用,而不是将其错误解释为变量。如果事先不知道名为day=的方法,那么day="x"在Ruby中看起来就像一个变量赋值。self.day="x"始终是方法调用。之所以麻烦是因为name和name=方法是在解析

mysql - Rails 数据库连接池的工作原理

我正在学习Rails数据库连接池概念。在Rails应用程序中,我将池大小定义为5。我对连接池大小的理解如下。当服务器启动时,rails会自动创建n个在database.yml文件中定义的连接。在我的例子中,它将创建5个连接,因为池大小为5。在每个http请求上,如果需要访问数据库,rails将使用连接池中的可用连接来处理请求。但我的问题是,如果我一次达到1000个请求,那么大部分请求将无法访问数据库连接,因为我的连接池大小只有5个。我上面对rails连接池的理解对吗??谢谢, 最佳答案 目的:数据库连接不是线程安全的;所以Activ

ruby-on-rails - 为什么 ActiveRecord 的自动保存对我的关联不起作用?

我有一个看起来像这样的ActiveRecord类。classFoobelongs_to:bar,autosave:truebefore_save:modify_bar...end如果我做一些日志记录,我看到bar正在被修改,但它的更改没有保存。怎么了? 最佳答案 这里的问题是autosave:true只是简单地设置了一个普通的before_save回调,而before_save回调是按照它们的顺序运行的'已创建。**因此,它尝试保存没有变化的bar,然后它调用modify_bar。解决方案是确保modify_bar回调在自动保存之前

ruby - 如何在 ActiveRecord 中执行 LIKE % 查询?

我正在尝试查找一些包含特定字符串的项目。如果我这样做:MyModel.where("descriptionLIKE?",keyword)它将生成一个完全匹配的查询。我想让它生成一个LIKE%keyword%查询。我该怎么做? 最佳答案 like_keyword="%#{keyword}%"MyModel.where("descriptionLIKE?",like_keyword) 关于ruby-如何在ActiveRecord中执行LIKE%查询?,我们在StackOverflow上找到一