У меня есть таблица http://img36.imageshack.us/i/beztytuuszxq.png/ и отображение:
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; }
}
Когда я хочу сохранить объект Category в db, когда для свойства Parent установлено значение null, у меня возникает исключение:
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>'
Я не знаю, что изменить, чтобы иметь возможность сохранять объекты Категории без родителей.