У меня есть таблица http://img36.imageshack.us/i/beztytuuszxq.png/ и отображение:NHibernate + свободно + отображение
public class CategoryMap : ClassMap<Category>
{
public CategoryMap()
{
Table(FieldNames.Category.Table);
Id(x => x.ID);
Map(x => x.Name).Not.Nullable();
Map(x => x.ShowInMenuBar).Not.Nullable();
References(x => x.Parent).Column(FieldNames.Category.ID).Nullable();
HasMany(x => x.Articles).Cascade.All().Inverse().Table(FieldNames.Article.Table);
}
}
Лицо выглядит, что:
public class Category : EntityBase
{
public virtual int ID { set; get; }
public virtual string Name { set; get; }
public virtual Category Parent { set; get; }
public virtual bool ShowInMenuBar { set; get; }
public virtual IList<Article> Articles { set; get; }
}
Когда я хочу, чтобы сохранить объект категории в дб, когда Родитель свойство установлен в нуль, у меня есть исключение:
not-null property references a null or transient value CMS.Domain.Entities.Article.Category
Я не могу изменить линию
public virtual Category Parent { set; get; }
в
public virtual Category? Parent { set; get; }
или
public virtual Nullable<Category> Parent { set; get; }
, потому что у меня есть ошибка во время компиляции:
CMS.Domain.Entities.Category' must be a non-nullable value type in order to use it as parameter 'T' in the generic type or method 'System.Nullable<T>'
Я не знать, что менять, чтобы иметь возможность сохранять объекты категории без родителей.