實體框架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();    

我的測試代碼:

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

(完整的程序代碼: http//pastebin.com/hSs9HZCP

它正確地插入和檢索具有指定id的記錄,並且該表具有指定的正確主鍵。

這是生成的遷移代碼:

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



許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因
許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因