如何在一个Rails查询中巧妙融合两个模型的功能?

2026-04-11 19:383阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计344个文字,预计阅读时间需要2分钟。

如何在一个Rails查询中巧妙融合两个模型的功能?

我有两个不相关的模型(在数据库意义上),但有一些共同的列(如名称、电子邮件等)。+Class Account ActiveRecord:Baseend + LegacyAccount ActiveRecord:Baseend 由于各种原因,我无法将这些合并到单个模型中或进行合并操作。

我有两个不相关的模型(在db意义上)但有一些共同的列(名称,电子邮件等).

Class Account < ActiveRecord::Base end Class LegacyAccount < ActiveRecord::Base end

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

如何在一个Rails查询中巧妙融合两个模型的功能?

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

如果它们不能被数据库连接,那么也许你可以定义一个合并记录并返回哈希的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对象的数组.

本文共计344个文字,预计阅读时间需要2分钟。

如何在一个Rails查询中巧妙融合两个模型的功能?

我有两个不相关的模型(在数据库意义上),但有一些共同的列(如名称、电子邮件等)。+Class Account ActiveRecord:Baseend + LegacyAccount ActiveRecord:Baseend 由于各种原因,我无法将这些合并到单个模型中或进行合并操作。

我有两个不相关的模型(在db意义上)但有一些共同的列(名称,电子邮件等).

Class Account < ActiveRecord::Base end Class LegacyAccount < ActiveRecord::Base end

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

如何在一个Rails查询中巧妙融合两个模型的功能?

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

如果它们不能被数据库连接,那么也许你可以定义一个合并记录并返回哈希的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对象的数组.