Entity Framework 7 IDENTITY_INSERT

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

質問

私は、すべてのユーザーが既にIDをキーとして持つデータベースに大量のユーザーデータを格納する必要があります。しかし、これらのユーザーはすべて、より大きなユーザープールの外にあるため、IDは増分せず、自動的に生成することもできません。私はIDを手動で設定できる必要があります。

これを行う簡単な方法はありますか?

受け入れられた回答

私はいくつかのテストをしましたが、これはEF 7.0.0 rc1-finalで私にとってはうまくいくようです:

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

私のテストコード:

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}");
    }
}

(フルプログラムコードはこちら: http : //pastebin.com/hSs9HZCP

指定されたIDを持つレコードが正しく挿入および取得され、正しいプライマリキーが指定されています。

これは生成された移行コードです。

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

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ