草庐IT

ActiveRecord_Relation

全部标签

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 - pg_dump : [archiver (db)] query failed: ERROR: permission denied for relation abouts

我正在尝试转储我的pgdb但遇到这些错误请建议pg_dump:[archiver(db)]queryfailed:ERROR:permissiondeniedforrelationaboutspg_dump:[archiver(db)]querywas:LOCKTABLEpublic.aboutsINACCESSSHAREMODE 最佳答案 您正在执行pg_dump的用户没有公共(public)模式的权限。如果允许则添加权限:GRANTUSAGEONSCHEMApublicTO;GRANTSELECTONALLTABLESINSCH

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

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

ruby - 在不保存的情况下运行 ActiveRecord 验证

我有一组ActiveRecord对象。我希望能够为这些对象中的每一个运行所有验证,而无需将它们实际保存到数据库中。我只想知道如果我将它们保存到数据库中它们是否有效。换句话说,我基本上想为我的每个对象填充errors数据结构。有没有办法做到这一点?或者我可能遗漏了一些关于errors集合的生命周期的信息? 最佳答案 您可以执行以下操作来检查模型是否有效:@user=User.newif@user.valid?#dothings如果你想看看错误是什么,你可以这样做:@user=User.newunless@user.valid?@use

ruby-on-rails - Rails:ActiveRecord::HasManyThroughSourceAssociationNotFoundError:找不到源关联

我有以下代码(有点简化......create_table:signaturesdo|t|t.integer:signer_idt.integer:card_idt.timestampsend模型看起来像......classSignature:signatures,:foreign_key=>"card_id"endclassUser"Card",:foreign_key=>"sender_id"has_many:received_cards,:class_name=>"Card",:foreign_key=>"recipient_id"has_many:signatureshas_

ruby-on-rails - Rails ActiveRecord 在一次查询中执行分组、求和和计数

我有两个表,Order(ID,Value)和OrderType(ID,Name[Quote,Sale,Purchase,etc])我想获得每种类型的订单总数(count)和每种类型的订单总值(value)(sum)我可以单独使用Order.group(:order_type).count(:id)和Order.group(:order_type).sum(:value)我想在一个查询中执行这些,相当于下面的SQLSELECTorder_types.id,Count(*)astotal_count,Sum(orders.value)Astotal_valueFROMorderJOINor

ruby-on-rails - 没有主键的 ActiveRecord 模型

我有一个没有主键的ActiveRecord模型GPA:classGPA当我尝试调用GPA.first.to_json时,我得到了TypeError:falseisnotasymbol。我猜这是由于ActiveRecord试图查找主键。在没有主键的情况下实现模型的正确方法是什么? 最佳答案 通常有一些列或列的组合共同构成一个主键。当您说您的表没有主键时,您的意思是它没有id字段吗?是否有另一列是唯一/自然键?如果是这样,您可以这样做:classGPA您还可以将复合键与compositekeysgem结合使用,如下:classGPA

ruby - 在 ruby​​/ActiveRecord 中生成类似 Instagram 或 Youtube 的不可猜测的字符串 ID

在创建给定ActiveRecord模型对象的实例后,我需要生成一个简短的(6-8个字符)唯一字符串用作URL中的标识符,采用Instagram照片URL的样式(如http://instagram.com/p/P541i4ErdL/,它我只是争先恐后地成为404)或Youtube的视频网址(如http://www.youtube.com/watch?v=oHg5SJYRHA0)。执行此操作的最佳方法是什么?最简单的是createarandomstring重复直到它是唯一的?有没有一种方法可以对整数ID进行散列/洗牌,使用户无法通过更改一个字符来破解URL(就像我对上面的404'sInst

ruby-on-rails - Rails (ActiveRecord) 多对多表

我有两个模型,用户和组。每个组可以有多个用户,每个用户可以在多个组中。我目前有一些简单的东西,比如:用户:has_many:groups组:has_many:users所以我有一个groups_users表,它只是用group_id和user_id创建行。我想为此添加另一列(我有),问题是如何在不使用自定义SQL调用的情况下从模型访问它?在组模型中,我可以使用self.users,在用户中,我可以使用self.groups有没有办法从用户模型更改此表中的第三列?对不起,如果这令人困惑,请就此提出建议 最佳答案 这里有一些教程应该会有

sql - 如何查询存储在数组中的 Rails ActiveRecord 数据

我有一个名为MentorData的Rails模型,它有一个名为os_usage的属性。这些ose存储在一个数组中,就像这样['apple','linux']。回顾一下:$MentorData.first.os_usage=>['apple','linux']我希望能够查询所有MentorData的数据,包括apple的os_usage,但是当我搜索MentorData.where(os_usage:'apple')我只得到只会用apple不会用apple和linux的导师。我需要以某种方式进行搜索以检查苹果是否包含在数组中。我也试过以下方法。MentorData.where('os_u