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

ruby-on-rails – 在Ruby on Rails Activerecord中将可计算列添

发布时间:2020-12-16 19:40:00 所属栏目:百科 来源:网络整理
导读:我有一个查询与很多联接,我渴望加载一些当时的关联.我需要计算一些值作为其中一个模型的属性. 所以,我正在尝试这个代码: ServiceObject .joins([{service_days: :ou},:address]) .eager_load(:address,:service_days) .where(ous: {id: OU.where(sector_cod
我有一个查询与很多联接,我渴望加载一些当时的关联.我需要计算一些值作为其中一个模型的属性.

所以,我正在尝试这个代码:

ServiceObject
  .joins([{service_days: :ou},:address])
  .eager_load(:address,:service_days)
  .where(ous: {id: OU.where(sector_code: 5)})
  .select('SDO_CONTAINS(ous.service_area_shape,SDO_GEOMETRY(2001,8307,sdo_point_type(addresses.lat,addresses.lng,NULL),NULL,NULL) ) AS in_zone')

其中SQL函数调用select操作来自关联地址和表的数据.

我得到下一个SQL(所以我的in_zone列获得计算并返回为所有eager_loaded模型的其他列之前的第一列):

SELECT SDO_CONTAINS(ous.service_area_shape,NULL) ) AS in_zone,"SERVICE_OBJECTS"."ID" AS t0_r0,"SERVICE_OBJECTS"."TYPE" AS t0_r1,<omitted for brevity> AS t2_r36 FROM "SERVICE_OBJECTS" INNER JOIN "SERVICE_DAYS" ON "SERVICE_DAYS"."SERVICE_OBJECT_ID" = "SERVICE_OBJECTS"."ID" INNER JOIN "OUS" ON "OUS"."ID" = "SERVICE_DAYS"."OU_ID" INNER JOIN "ADDRESSES" ON "ADDRESSES"."ID" = "SERVICE_OBJECTS"."ADDRESS_ID" WHERE "OUS"."ID" IN (SELECT "OUS"."ID" FROM "OUS" WHERE "OUS"."SECTOR_CODE" = :a1)  [["sector_code","5"]]

但是似乎in_zone无法从查询中使用的任一模型访问.

我需要计算出in_zone作为ServiceObject模型对象的属性,我该如何才能完成?

Ruby on Rails 4.2.6,Ruby 2.3.0,oracle_enhanced适配器1.6.7,Oracle 12.1

解决方法

那个猴子补丁帮助@Envek:
module ActiveRecord
  Base.send :attr_accessor,:_row_

  module Associations
    class JoinDependency
      JoinBase && class JoinPart
        def instantiate_with_row(row,*args)
          instantiate_without_row(row,*args).tap { |i| i._row_ = row }
        end; alias_method_chain :instantiate,:row
      end
    end
  end
end

那么可以做到:

ServiceObject
  .joins([{service_days: :ou},NULL) ) AS in_zone')
  .first
  ._row_['in_zone']

(编辑:李大同)

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

    推荐文章
      热点阅读