Entity Framework 7 IDENTITY_INSERT

asp.net-core c# entity-framework entity-framework-core sql

Question

J'ai besoin de stocker une grande quantité de données utilisateur dans une base de données où chaque utilisateur a déjà un identifiant en tant que clé. Toutefois, ces utilisateurs appartenant tous à un groupe d'utilisateurs plus important, l'ID ne s'incrémente pas et ne peut pas être généré automatiquement. Je dois être capable de définir manuellement l'ID.

Y a-t-il un moyen facile de faire ceci?

Réponse acceptée

J'ai fait quelques tests et cela semble fonctionner pour moi sur EF 7.0.0 rc1-final:

modelBuilder.Entity<Foo>().HasKey(x => x.Id);
modelBuilder.Entity<Foo>().Property(x => x.Id).ValueGeneratedNever();    

Mon code de test:

static void Main(string[] args)
{
    using (var db = new FooContext())
    {
        var myFoo = new Foo {Id = 1002, Descr = "Test"};
        db.Add(myFoo);
        db.SaveChanges();
    }
    using (var db = new FooContext())
    {
        var myFoo = db.Foos.FirstOrDefault(x => x.Id == 1002);
        Console.WriteLine($"id = {myFoo?.Id}, descrip = {myFoo?.Descr}");
    }
}

(code complet du programme ici: http://pastebin.com/hSs9HZCP )

Il insère et récupère correctement un enregistrement avec l'ID spécifié et la table a la clé primaire correcte spécifiée.

C'est le code de migration généré:

migrationBuilder.CreateTable(
    name: "Foo",
    columns: table => new
    {
        Id = table.Column<long>(nullable: false),
        Descr = table.Column<string>(nullable: true)
    },
    constraints: table =>
    {
        table.PrimaryKey("PK_Foo", x => x.Id);
    });


Related

Sous licence: CC-BY-SA with attribution
Non affilié à Stack Overflow
Est-ce KB légal? Oui, apprenez pourquoi
Sous licence: CC-BY-SA with attribution
Non affilié à Stack Overflow
Est-ce KB légal? Oui, apprenez pourquoi