gpt4 book ai didi

ruby-on-rails - ActiveRecord find_all_by_X 是否保留顺序?如果不是,应该用什么代替?

转载 作者:行者123 更新时间:2023-12-03 15:38:55 26 4
gpt4 key购买 nike

假设我有一个非空数组 idsThing对象 ID,我想使用 things = Thing.find_all_by_id(ids) 找到相应的对象.我的印象是things不一定具有类似于 ids 的排序.

  • 我的印象正确吗?
  • 如果是这样,我可以用什么代替 find_all_by_id保留顺序并且不会不必要地多次访问数据库?
  • 最佳答案

  • 使用 Array#sort

  • 一探究竟:
    Thing.where(:id => ids).sort! {|a, b| ids.index(a.id) <=> ids.index(b.id)}
    where(:id => ids)将使用 IN() 生成查询.然后排序!方法将遍历查询结果并比较 ids 数组中 id 的位置。

    关于ruby-on-rails - ActiveRecord find_all_by_X 是否保留顺序?如果不是,应该用什么代替?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10037460/

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