Skip to content

Retrieve the primary key (including composite keys) from any entity

License

Notifications You must be signed in to change notification settings

NickStrupat/EntityFramework.PrimaryKey

Repository files navigation

EntityFramework.PrimaryKey

Retrieve the primary key (including composite keys) from any entity as a dictionary.

EF version .NET support NuGet package
6.1.3 >= Framework 4.6.1 NuGet Status
Core 2.0 >= Framework 4.6.1 || >= Standard 2.0 NuGet Status

Usage

public class QuestionTag {
    [Key, Column(Order = 0)] public Guid QuestionId { get; set; }
    [Key, Column(Order = 1)] public Int64 TagId { get; set; }
    public DateTime Inserted { get; set; }
}

var primaryKey = questionTag.GetPrimaryKey();
var questionId = (Guid) primaryKey[nameof(QuestionTag.QuestionId)];
var tagId = (Int64) primaryKey[nameof(QuestionTag.TagId)];

API

var primaryKeyDict = context.GetPrimaryKey(entity);
var primaryKeyDict = entity.GetPrimaryKey(); // auto-detects your DbContext class
var primaryKeyDict = entity.GetPrimaryKey(context);
var primaryKeyDict = entity.GetPrimaryKey<YourDbContext, YourEntity>();

How it works

The extension methods provide four different ways to get the primary key, but internally they run mostly the same code. The names of the properties are retrieved from the DbContext metadata, and a fast delegate is cached for each entity type when that type is first used. When the fast delegate is invoked with an entity, it creates a ReadOnlyDictionary<K, V> where the keys are the names of the properties which comprise that entity's primary key and the values are the value of each corresponding property.

Contributing

  1. Create an issue
  2. Let's find some point of agreement on your suggestion.
  3. Fork it!
  4. Create your feature branch: git checkout -b my-new-feature
  5. Commit your changes: git commit -am 'Add some feature'
  6. Push to the branch: git push origin my-new-feature
  7. Submit a pull request :D

History

Commit history

License

MIT License

About

Retrieve the primary key (including composite keys) from any entity

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages