sql >> データベース >  >> RDS >> PostgreSQL

Rails / postgres、「外部キー」を配列に格納して1-多くの関連付けを作成

    Railsにこの配列を認識させ、関連付けに使用することはできません。

    ただし、ユーザーに割り当てられたタスクをより迅速に検索/フィルタリングしたい場合は、タスクオブジェクトにユーザーIDの配列を保持できます。それ以外の場合は、標準の関連付けテーブルで、アリスに割り当てられているすべてのタスクを見つけるためにJOINを実行する必要があります。

    したがって、解決策は、関連付けテーブルを保持するだけでなく、担当者のユーザーIDをタスクオブジェクトに複製し、そのIDリストを使用して検索/フィルタリングを高速化することです。

    after_createにフックする必要があります およびafter_destroy 担当者オブジェクトのライフサイクルを実行し、新しい担当者IDをタスクレコード配列に挿入します。そして、署名者がタスクから削除されたら、配列を更新してIDを削除します。

    すべての配列演算子については、Postgresのドキュメントを参照してください:

    このようなもの:

    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. PHPWebアプリケーションでのタイムゾーンの使用

    2. php構文エラー、予期しないT_VARIABLE、29行目に'、'、または''が必要です

    3. リストするタプル-Python/PostgreSQLがSETOFレコードのタイプを返す

    4. SQL Serverはデータを分割する必要がありますが、StandardEditionのみがあります