c# - Entity Framework 7 IDENTITY_INSERT

标签 c# sql entity-framework asp.net-core entity-framework-core

我需要在数据库中存储大量用户数据,其中每个用户都已经有一个 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/

相关文章:

c# - 在.Net框架应用程序中调用.Net Core库中的方法

c# - 如何知道谁杀死了我的线程

c# - WPF UI 仅在调试时崩溃

c# - IDbConnection 和在 c# 中使用 block

php - 每次调用 mysql_query 时执行一个函数。 (PHP)

sql - SQL Server 中两列的重复值计数

sql - 只显示有效的 SQL 字符串 P6Spy

c# - EF 中的 db.SaveChanges() 参数超出范围

c# - EF 代码优先 : Sequence contains more than one matching element

c# - MVC 4 Beta - 在写入本地名称为 'type' 的属性后,您必须写入属性 ='object' '__type'