Nie będzie w stanie dokonać Szyny świadomi tej tablicy i użyć go do stowarzyszeń.
Ale jeśli chcesz szybciej wyszukiwać/filtrować zadania przypisane do użytkowników, możesz zachować tablicę identyfikatorów użytkowników w obiekcie zadania. W przeciwnym razie musisz wykonać JOIN, aby znaleźć wszystkie zadania przypisane Alice w standardowej tabeli powiązań.
Rozwiązaniem jest więc zachowanie tabeli powiązań, ale także skopiowanie identyfikatora użytkownika cesjonariusza w obiekcie zadania i użycie tej listy identyfikacyjnej do szybszego wyszukiwania/filtrowania.
Konieczne będzie przechwycenie w cykl życia after_create
i after_destroy
dla obiektów cesjonariusza i wstawienie nowych identyfikatorów Identyfikatora do tablicy rekordów Zadań. A następnie, gdy osoba wyznaczona zostanie usunięta z zadania, zaktualizuj tablicę, aby usunąć identyfikator.
See Postgres docs dla wszystkich operatorów tablicy:
coś takiego:
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
Będziesz zainteresowany wiedząc, że klucze obce tablicowe oparte są w trakcie opracowywania. Mogą dostać się do PostgreSQL 9.4, ale nie sądzę, że zrobili to dla 9.3. –