【问题标题】:Auto Increment (Identity) does not work in Fluent NHibernate自动增量(身份)在 Fluent NHibernate 中不起作用
【发布时间】:2017-10-31 08:58:26
【问题描述】:

我正在使用 Fluent Nhibernate。 映射类如下所示:

public class CategoryMap : ClassMap<Category>
{

    public CategoryMap()
    {
        Id(x => x.CategoryId).UniqueKey("CategoryId").GeneratedBy.Increment();
        Map(x => x.CategoryName).Not.Nullable();

        References(x => x.ParentCategory).Column("ParentCategoryId").Nullable();
    }
}

它像我需要的那样创建表,但在 SSMS 中我看到 CategoryId 不是身份。

为什么自动增量(身份)不起作用?

【问题讨论】:

  • 你回答了你自己的问题。自动增量不起作用,因为该列是标识 = 否。创建表时,您需要将列属性指定为 IDENTITY( [seed], [increment]) 或简单地 IDENTITY 将默认为 (1,1) 作为种子/增量。

标签: c# sql-server mapping fluent-nhibernate auto-increment


【解决方案1】:

使用Identity而不是Increment,并且您不需要指定UniqueKey,因为主键必须是唯一的。

Id(x => x.CategoryId).GeneratedBy.Identity();

我不确定 Increment 的用例是什么或最新的 NHibernate 文档在哪里,但您可以在此处阅读第 5.1.5.1 节中的不同类型的 ID 生成器:http://nhibernate.info/doc/nhibernate-reference/mapping.html

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2023-03-31
    • 2010-12-14
    • 2015-11-22
    • 2013-05-25
    • 2023-03-21
    • 1970-01-01
    • 2020-03-30
    • 1970-01-01
    相关资源
    最近更新 更多