sql >> Databasteknik >  >> RDS >> PostgreSQL

Rails/postgres, "främmande nycklar" lagras i array för att skapa 1-många association

Du kommer inte att kunna göra Rails medveten om denna array och använda den för associationer.

Men om du vill ha snabbare sökning/filtrering av uppgifter som tilldelats användare kan du behålla en rad användar-ID:n i uppgiftsobjektet. Annars måste du göra en JOIN för att hitta alla uppgifter som tilldelats Alice, i din vanliga associationstabell.

Så lösningen är att behålla associationstabellen men också duplicera den tilldelade användar-ID:t till Task-objektet och använda den ID-listan för snabbare sökning/filtrering.

Du måste ansluta till after_create och after_destroy livscykel för tilldelade objekten och infoga nya tilldelade ID:n i aktivitetspostmatrisen. Och sedan när en tilldelad mottagare tas bort från en uppgift uppdatera arrayen för att ta bort ID:t.

Se Postgres docs för alla Array-operatorer:

Något så här:

class Task < ActiveRecord::Base
    has_many :assignees, :dependent => :destroy
end

class Asignee < ActiveRecord::Base

    belongs_to :task
    after_create :insert_task_assignee
    after_destroy :remove_task_assignee

    # assumes that there is a column called assignee_id
    # that contains the User ID of the assigned person

    private

    def insert_task_assignee
        # TODO: check for duplicates here - before we naively push it on?
        task.assignee_list = task.assignee_list.push(assignee_id)
        task.assignee_list.save
    end

    def remove_task_assignee
        id_list = task.assignee_list
        id_list.reject! { |candidate_id| candidate_id == assignee_id }
        task.assignee_list = id_list
        task.assignee_list.save
    end

end

# find all tasks that have been assigned Alice & Bob
# this will require the `postgres_ext` gem for Ruby / Postgres array searching
tasks = Task.where.contains(:assignee_list => [alice.id, bob.id]).all



  1. Använda Google Cloud SQL under utveckling av Java-appenginer (istället för lokal MySQL-instans)

  2. Mysql-fråga som returnerar kategoriträd

  3. Fel java.sql.SQLEundantag:ORA-00911:ogiltigt tecken

  4. postgreSQL.app :skapa databas