正在开发RoR应用程序。考虑一下Tinder for art,它有一点基本的人工智能。如果你喜欢或不喜欢艺术,这款应用会根据其他用户的喜好,向你展示你希望更喜欢的艺术。我正在编写代码,以选择下一个要显示的图像。
我使用以下模型:
用户基本信息:
class User < ApplicationRecord
has_many :artworks
has_many :artists
has_many :art_views
end关于每件的信息(价格,高度,宽度等)
class Artwork < ApplicationRecord
belongs_to :user
belongs_to :artist
has_many :art_views
end表示向用户展示了哪些艺术(boolean liked表示用户是否喜欢该艺术作品)
class ArtView < ApplicationRecord
belongs_to :user
belongs_to :artwork
end逻辑很简单:在找到current_user (在ArtView中)喜欢的最后一个艺术作品后,找到其他也喜欢相同艺术作品(也是在ArtView中)的用户,然后找到current_user没有看到的其他用户喜欢的新艺术作品(在ArtView中没有记录)
我正在使用下面的连接:
@artwork = Artwork.joins(:artview)
.where(:artviews => { :liked => true})
.where(:artviews => { :artwork_id => @artwork_id})
.where.not(:artviews => { user_id: @id })我得到以下错误:
Can't join 'Artwork' to association named 'artview'; perhaps you misspelled it?非常感谢任何指导/建议(通常是在修复错误和/或改进逻辑方面)
发布于 2020-07-21 13:21:32
一个ArtView有许多ArtViews,所以在使用joins时必须引用这些关系。
它应该是这样工作的:
Artwork.joins(:art_views)在使用joined列时也是如此(不管是哪种关系),您应该使用表的“真实”名称;这是一种复数形式--这就是Rails如何命名它创建的表,除非另有说明:
Artwork
.joins(:art_views)
.where(:art_views => { :liked => true})
.where(:art_views => { :artwork_id => @artwork_id})
.where.not(:art_views => { user_id: @id })https://stackoverflow.com/questions/63007081
复制相似问题