PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Railsy/postgres, 'klucze obce' przechowywane w tablicy w celu utworzenia asocjacji 1-wielu

Nie będziesz w stanie poinformować Railsów o tej tablicy i użyć jej do skojarzeń.

Ale jeśli chcesz szybszego wyszukiwania / filtrowania zadań przypisanych do użytkowników, możesz zachować tablicę identyfikatorów użytkowników w obiekcie zadania. W przeciwnym razie musiałbyś wykonać JOIN, aby znaleźć wszystkie zadania przypisane do Alicji w standardowej tabeli asocjacji.

Rozwiązaniem jest więc zachowanie tabeli skojarzeń, ale także zduplikowanie przypisanego identyfikatora użytkownika do obiektu Task i użycie tej listy identyfikatorów do szybszego wyszukiwania/filtrowania.

Musisz podłączyć się do after_create i after_destroy cykl życia obiektów cesjonariuszy i wstaw nowe identyfikatory cesjonariuszy do tablicy rekordów zadań. A następnie, gdy cesjonariusz zostanie usunięty z zadania, zaktualizuj tablicę, aby usunąć identyfikator.

Zobacz dokumentację Postgres dla wszystkich operatorów tablic:

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



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Importuj bibliotekę psycopg2 nie załadowaną:libssl.1.0.0.dylib

  2. Uzyskaj wszystkie klucze obce za pomocą JDBC

  3. agregat pustego zbioru wyników

  4. Jak dodać 2 punkty wraz z odległością między nimi (SRID =32636)?

  5. Sprawdź, czy wartość istnieje w tablicy Postgres