我需要在每个用户已经有一个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); });