簡體   English   中英

實體框架7 IDENTITY_INSERT

[英]Entity Framework 7 IDENTITY_INSERT

我需要在每個用戶已經有一個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);
    });

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM