草庐IT

多表关联

全部标签

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) 多对多表

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

ruby-on-rails - 如何验证关联的模型 ID?

我有一个学生和一个类(class)模型。学生属于类(class),类(class)有很多学生。classStudenttruevalidates_associated:courseendclassCoursetruevalidates:courseCode,:courseYr,:uniqueness=>{:message=>"Cannotrepeatthecode"}has_many:studentsend在用于创建学生记录的表单中,我让用户输入类(class)ID。但我不知道如何验证用户输入的course_id。学生模型验证不会产生错误,即使我键入不存在的类(class)ID。如何让

ruby-on-rails - 跳过与 simple_form 关联的包装器

我正在使用simple_form,我想知道在处理关联选择时是否可以跳过任何包装div。谢谢 最佳答案 如果您使用类似f.association:product的东西,您可以像这样删除生成的标签和包装器:f.association:product,label:false,wrapper:false 关于ruby-on-rails-跳过与simple_form关联的包装器,我们在StackOverflow上找到一个类似的问题: https://stackoverf

ruby-on-rails - 无法在 Rails 3 中找到 has_many 的逆关联

我有以下模型:classBusiness:businesshas_many:payments,:inverse_of=>:businessendclassCustomer:customerhas_many:payments,:inverse_of=>:customerendclassPayment:paymentbelongs_to:business,:inverse_of=>:paymentend执行business.customers效果很好。但是,当我执行business.payments时,出现错误:Couldnotfindtheinverseassociationforbus

ruby-on-rails - 自定义 rails has_many 关联(通过 pg 数组)

所以基本上我想知道是否有一些通用方法来定义自己的关联类型。一些细节:我有一个模型conversations有一个PG数组列user_ids.因此,要检索我需要运行的用户对话:selectconversations.*fromconversationswhereUSER_ID=ANY(conversations.user_ids)自finder_sql它的friend现在已被弃用,我真的很想知道实现这个伪has_many关联的最佳方法是什么?目前我只使用如下方法:defconversationsConversation.where("#{id}=ANY(conversations.use

ruby-on-rails - 使用具有嵌套关联的多态路径

我有一个看起来像这样的多态关联:classLinetrueendclassEducation:itemendclassWork:itemend我想要一种从父项创建新行的简单方法。因此,我可能正在编辑Work对象的View,并希望有一个创建新Line对象的链接。通常,我会这样做:助手会为此制定路线。但是,这需要我检查Line在Controller中属于哪个父级,从而违背了多态性的目的(如果是这样的话,我本可以使用两个引用)。所以,我的问题是,如何让路径像普通路径助手一样以多态方式工作? 最佳答案 一种可能的方法是使用这样的路由:map

ruby-on-rails - 查找关联记录存在的位置

我如何才能只选择那些具有关联标签记录的员工?换句话说,只选择具有一个或多个与之相关联的标签记录的员工记录。classEmployee下面的查询(这是错误的)会让你们了解我正在尝试做什么。Employee.includes(:tags).where("tags.id!=nil") 最佳答案 您可以使用.joinsEmployee.joins(:tags)此生成的SQL包含tags表上的INNERJOIN,省略没有关联tagsemployees表记录记录。 关于ruby-on-rails-查

ruby-on-rails - 将参数括起来以确保该 block 将与方法调用相关联

classUserscope:active,->{where(active:true)}end运行rubocop我收到以下警告:Parenthesizetheparam->{where(active:true)}tomakesurethattheblockwillbeassociatedwiththe->methodcall.我完全不知道我的scope定义与这个警告有什么关系。你呢?除了关闭检查之外,我该如何修复警告,因为它目前没有意义? 最佳答案 它要你这样做:scope:active,(->{where(active:true)

ruby - 始终渴望加载与实体的关联

是否可以在加载实体时始终预加载关联。例如classBookhas_many:chaptersendclassChaptersbelongs_to:bookendbook=Book.find_by_title('MobyDick')我知道您可以在调用中查找ie中的eagerload。book=Book.find_by_title('MobyDick',:include=>:chapters)但在这种情况下,我知道每当我找到一本书时,我总是希望急切加载章节而不需要记住:include=>参数。 最佳答案 您可以在模型中包含“defaul