首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于semi AI应用程序的RoR ActiveRecord Join帮助

用于semi AI应用程序的RoR ActiveRecord Join帮助
EN

Stack Overflow用户
提问于 2020-07-21 11:51:44
回答 1查看 30关注 0票数 1

正在开发RoR应用程序。考虑一下Tinder for art,它有一点基本的人工智能。如果你喜欢或不喜欢艺术,这款应用会根据其他用户的喜好,向你展示你希望更喜欢的艺术。我正在编写代码,以选择下一个要显示的图像。

我使用以下模型:

用户基本信息:

代码语言:javascript
复制
class User < ApplicationRecord
  has_many :artworks
  has_many :artists
  has_many :art_views
end

关于每件的信息(价格,高度,宽度等)

代码语言:javascript
复制
class Artwork < ApplicationRecord
  belongs_to :user
  belongs_to :artist
  has_many :art_views
end

表示向用户展示了哪些艺术(boolean liked表示用户是否喜欢该艺术作品)

代码语言:javascript
复制
class ArtView < ApplicationRecord
  belongs_to :user
  belongs_to :artwork
end

逻辑很简单:在找到current_user (在ArtView中)喜欢的最后一个艺术作品后,找到其他也喜欢相同艺术作品(也是在ArtView中)的用户,然后找到current_user没有看到的其他用户喜欢的新艺术作品(在ArtView中没有记录)

我正在使用下面的连接:

代码语言:javascript
复制
@artwork = Artwork.joins(:artview)
  .where(:artviews => { :liked => true})
  .where(:artviews => { :artwork_id => @artwork_id})
  .where.not(:artviews => { user_id: @id })

我得到以下错误:

代码语言:javascript
复制
Can't join 'Artwork' to association named 'artview'; perhaps you misspelled it?

非常感谢任何指导/建议(通常是在修复错误和/或改进逻辑方面)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-07-21 13:21:32

一个ArtView有许多ArtViews,所以在使用joins时必须引用这些关系。

它应该是这样工作的:

代码语言:javascript
复制
Artwork.joins(:art_views)

在使用joined列时也是如此(不管是哪种关系),您应该使用表的“真实”名称;这是一种复数形式--这就是Rails如何命名它创建的表,除非另有说明:

代码语言:javascript
复制
Artwork
  .joins(:art_views)
  .where(:art_views => { :liked => true})
  .where(:art_views => { :artwork_id => @artwork_id})
  .where.not(:art_views => { user_id: @id })
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63007081

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档