Rails 中使用 Arel 实现外连接查询

例如有以下几个表

users: id
groups: id
resources: id, user_id(创建资源的用户), group_id(资源组)
users_resoures: user_id, resource_id (按用户授权资源)
users_groups: user_id, group_id (按组授权资源)

需求:

  1. 用户可以访问自己创建的资源
  2. 用户可以访问所属分组的资源
  3. 用户可以访问单独授权的资源

用 arel 来实现

class Resource < ActiveRecord::Base

  def self.accessible_by(user)
    users_resources = Arel::Table.new(:users_resources)
    resources = arel_table

    left_outer = resources.join(users_resources, Arel::Nodes::OuterJoin).on(
      users_resources[:resource_id].eq(resources[:id])
    ).join_sources

    filters = resources[:user_id].eq(user.id)
      .or(resources[:group_id].in(user.group_ids))
      .or(users_resources[:user_id].eq(user.id))

    joins(left_outer).where(filters)
  end

end
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,933评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,765评论 18 399
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,315评论 25 708
  • 童年 我未遇见你の 你也错过了我の 但是这一生 我们相伴走过 从我二十四岁起 那时你已近四十 你说把我们的故事写成...
    不想忘记的太多阅读 148评论 0 0
  • UITableViewCell的选中时的颜色设置 1.系统默认的颜色设置 2.自定义颜色和背景设置 改变UITab...
    转身一世琉璃白阅读 10,567评论 0 4