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

Add support for collections of primitive types as separate table in relational databases #25163

Open
Tracked by #30731
qetza opened this issue Jun 28, 2021 · 6 comments

Comments

@qetza
Copy link

qetza commented Jun 28, 2021

Currently it's not possible to store collections of primitive types in their own table so that we can easily query on those values. All proposed solutions are to serialize the collection but this does not allow for querying it's content easily or to create a class with a single property to represent the new table.

Through configuration it would be great to be able to define a table assigned to the collection so that it can be stored in it's own table with a foreign key referencing the parent entity. This could be configured like a collection of owned entities stored in it's own table where the value of the collection is the only column (with the foreign key).

So the entity:

public class Role
{
  public string Id { get; set; }
  public string Name { get; set; }
  public ICollection<string> Members { get; set; }
}

with the following configuration:

modelBuilder.Entity<Role>().OwnsMany(
    r => r.Members, 
    b => {
        b.ToTable("RoleMembers");
        b.WithOwner().HasForeignKey("RoleId");
        b.Property(b => b).HasColumnName("Name");
        b.HasKey("RoleId", "Name");
    });

would be persisted in 2 tables:

  • Roles
    • Id
    • Name
  • RoleMembers
    • RoleId
    • Name
@AndriySvyryd
Copy link
Member

Part of #4179

@ajcvickers
Copy link
Contributor

Contrast to #29427.

Note from triage: also consider other issues related to primitive collections--see label area-primitive-collections.

@roji
Copy link
Member

roji commented Oct 30, 2022

image

@ajcvickers
Copy link
Contributor

@roji Did you see this label?

(We needed a label for things we needed to talk to you about when you got back...)

@roji
Copy link
Member

roji commented Oct 30, 2022

Of course I saw it :) And I thought it was only a mechanism for trolling me 🤣

@ajcvickers
Copy link
Contributor

Of course I saw it :) And I thought it was only a mechanism for trolling me 🤣

Well, that was the primary concern.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants