gpt4 book ai didi

mysql - Rails Arel,从同一列中选择但有多个值

转载 作者:太空宇宙 更新时间:2023-11-03 16:51:04 24 4
gpt4 key购买 nike

我有一个名为 cherry_picker_cherries 的表。这些记录多态地属于一个名为 Pickable 的模型。他们可以在表中为同一个 pickable 设置多个条目,但它始终具有不同的 cherry_pick_id

我的问题:我有一个名为 Favorite Tree 的 cherry-pick 和一个名为 Favorite Fruit 的单独 cherry_pick。我希望能够通过多个 cherry picks 过滤一组 pickables。例如,我想找到所有最喜欢的树是 cherry 并且最喜欢的水果是 orange

我可以使用以下方法以糟糕的方式完成此操作:


CherryPicker::Cherry.find_by_sql("SELECT * from cherry_picker_cherries t1 JOIN cherry_picker_cherries t2 USING(pickable_id) WHERE t1.value = 'orange'AND t2.value = 'cherry'")

但是,这种方法有几个缺点。它不能处理更多的 Cherry Picks,现在只有两个。此外,结果集被转换为一个数组,但我需要返回一个 ActiveRecord 关系,以便我可以继续将方法链接到它上面。

我试图查看 AREL 是否有某种解决方案来生成与上述匹配的简单查询,但我陷入了死胡同。遍历参数的散列以允许您可以筛选 2、3、4 或 X 数量的樱桃选择将很容易。

这在 AREL、rails 或其他任何东西中甚至可能吗?

最佳答案

你能试一试吗?

CherryPicker::Cherry.joins("join cherry_picker_cherries t2 using(pickable_id)").where("cherry_picker_cherries.value = ? and t2.value = ?", 'orange', 'cherry')

如果可行,您可以遍历要加入的水果并使用递增的变量名称(t3、t4.. 等)执行另一个加入,因为直到 sql 查询才会执行这是需要的。

以下是多次连接同一个表的方法:

arr = ['orange', 'cherry', 'apple']

query = CherryPicker::Cherry.joins("join cherry_picker_cherries t0 using(pickable_id)")

arr.drop(2).each_with_index do |e,i|
query = query.joins("join cherry_picker_cherries t#{i+1} using(pickable_id)")
end

你可以做同样的事情来生成你的where

如果你能提出修改建议那就太好了,这样我就可以改进这篇文章,因为没有你的表格真的很难测试 =)

关于mysql - Rails Arel,从同一列中选择但有多个值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21689795/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com