我需要在数据库中存储大量用户数据,其中每个用户都已经有一个 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);
});
关于c# - Entity Framework 7 IDENTITY_INSERT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34729106/