Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support multi-column foreign keys #81

Closed
andrew-farries opened this issue Sep 5, 2023 · 5 comments · Fixed by #471
Closed

Support multi-column foreign keys #81

andrew-farries opened this issue Sep 5, 2023 · 5 comments · Fixed by #471
Assignees
Labels
enhancement New feature or request
Milestone

Comments

@andrew-farries
Copy link
Collaborator

The current implementation (#73 and #79) allows for foreign key constraints to be added to an individual columns, referencing one column in the target table.

This should be extended to allow foreign key constraints to be defined at the table level so they can span multiple columns.

@saintazunya
Copy link

Hi,

Firstly, I would like to express my gratitude for your efforts in developing and maintaining this valuable tool. It's been instrumental in many of my projects, and I truly appreciate the work you've put into it.

I'm writing to inquire about the current support for composite keys and indexes in pgroll. Based on my experiances, not only foreign keys are not supported, but also

  • Composite Primary Keys
  • Composite Unique Keys
  • Composite Indexes

are not supported for now.

These features are crucial for the implementation of complex data models where single-column keys are insufficient to ensure data integrity and performance optimization.

Do we have a plan on supporting these yet?

Thanks.

@exekias
Copy link
Member

exekias commented Nov 10, 2023

Thank you for your feedback! This is indeed something we want to tackle soon, as it's an important limitation. Now that we have all the foundations in place it feels like we are ready to start working on this.

@SferaDev
Copy link
Member

Also faced this in one of my tests:

CREATE TABLE IF NOT EXISTS "users_to_groups" (
        "id" serial PRIMARY KEY NOT NULL,
        "user_id" integer NOT NULL,
        "group_id" integer NOT NULL,
        CONSTRAINT "users_to_groups_group_id_user_id_pk" PRIMARY KEY("group_id","user_id")
);

Error: unable to execute start operation: pq: multiple primary keys for table "users_to_groups" are not allowed

@chris-braidwell
Copy link

Error: unable to execute start operation: pq: multiple primary keys for table "users_to_groups" are not allowed

This isn't a pgroll limitation. Postgres doesn't support multiple PKs in a table. You can create unique constraints that function very similarly to a PK (e.g. can be the parent side of an FK relationship) but there can be only one "primary" key.

@andrew-farries andrew-farries added this to the v1 milestone Oct 14, 2024
@kvch kvch self-assigned this Oct 15, 2024
@kvch
Copy link
Contributor

kvch commented Oct 16, 2024

@saintazunya I created a separate issue for your request: #409

andrew-farries added a commit that referenced this issue Nov 22, 2024
…aint` (#471)

This PR introduces a new constraint `type` to `create_constraint`
operation called `foreign_key`. Now it is possible to create FK
constraints on multiple columns.

### Examples

#### Foreign key

```json
{
  "name": "44_add_foreign_key_table_reference_constraint",
  "operations": [
    {
      "create_constraint": {
        "type": "foreign_key",
        "table": "tickets",
        "name": "fk_sellers",
        "columns": [
          "sellers_name",
          "sellers_zip"
        ],
        "references": {
          "table": "sellers",
          "columns": [
            "name",
            "zip"
          ],
          "on_delete": "CASCADE"
        },
        "up": {
          "sellers_name": "sellers_name",
          "sellers_zip": "sellers_zip"
        },
        "down": {
          "sellers_name": "sellers_name",
          "sellers_zip": "sellers_zip"
        }
      }
    }
  ]
}
```

Closes #81

---------

Co-authored-by: Andrew Farries <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
6 participants