Rails 中使用 Arel 實(shí)現(xiàn)外連接查詢

例如有以下幾個(gè)表

users: id
groups: id
resources: id, user_id(創(chuàng)建資源的用戶), group_id(資源組)
users_resoures: user_id, resource_id (按用戶授權(quán)資源)
users_groups: user_id, group_id (按組授權(quán)資源)

需求:

  1. 用戶可以訪問自己創(chuàng)建的資源
  2. 用戶可以訪問所屬分組的資源
  3. 用戶可以訪問單獨(dú)授權(quán)的資源

用 arel 來實(shí)現(xiàn)

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
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,506評論 19 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,626評論 18 399
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,781評論 25 709
  • 童年 我未遇見你の 你也錯(cuò)過了我の 但是這一生 我們相伴走過 從我二十四歲起 那時(shí)你已近四十 你說把我們的故事寫成...
    不想忘記的太多閱讀 161評論 0 0
  • UITableViewCell的選中時(shí)的顏色設(shè)置 1.系統(tǒng)默認(rèn)的顏色設(shè)置 2.自定義顏色和背景設(shè)置 改變UITab...
    轉(zhuǎn)身一世琉璃白閱讀 10,633評論 0 4

友情鏈接更多精彩內(nèi)容