加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 如何将2个Rails模型混合到单个查找中?

发布时间:2020-12-17 01:22:29 所属栏目:百科 来源:网络整理
导读:我有两个不相关的模型(在db意义上)但有一些共同的列(名称,电子邮件等). Class Account ActiveRecord::BaseendClass LegacyAccount ActiveRecord::Baseend 由于各种原因,我无法将这些合并到单个模型中或进行STI.但我想要一个简单的视图,在一个漂亮的表中显示
我有两个不相关的模型(在db意义上)但有一些共同的列(名称,电子邮件等).

Class Account < ActiveRecord::Base

end


Class LegacyAccount < ActiveRecord::Base

end

由于各种原因,我无法将这些合并到单个模型中或进行STI.但我想要一个简单的视图,在一个漂亮的表中显示两个模型的所有记录(可能按照“name”这样的公共字段排序).

是否可以从两个模型中进行查找/查询?或者,我可以执行两个查找并合并生成的数组,以便对它们进行排序吗?我可以使用一些中间模型来合并它们吗?

解决方法

如果它们不能被数据库连接,那么也许你可以定义一个合并记录并返回哈希的Ruby对象.

class AccountView
  def self.find_all
    accounts = []
    Account.find(:all).each do |account|
      accounts << {:name => account.name,... }
    end
    LegacyAccount.find(:all).each do |account|
      accounts << {:name => account.name,... }
    end
    return accounts
  end
end

或者,在AccountView上定义属性并返回AccountView对象的数组.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读