Я сделал несколько тестов, и это, кажется, работает для меня на EF 7.0.0 rc1-финал:
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)
Он правильно вставляет и извлекает запись с указанным идентификатором, а в таблице указан правильный первичный ключ.
Это код миграции генерируется:
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);
});
ли вы связаны данные, ссылающихся эти идентификаторы, а? В любом случае, это не похоже на то, что EF является правильным инструментом для работы - подумайте об использовании инструмента ETL или написании соответствующих инструкций INSERT. –
Не можете ли вы просто войти в файл .edmx и установить SoreGeneratedPattern для этого свойства в «none»? Или я чего-то не хватает? – Dave
@Dave Я не думаю, что EF7 использует файлы edmx – Jcl