Why does NHibernate require "protected internal" visibility on auto properties?
It used to be possible to map auto properties with private setters with NHibernate, but starting with version 3.2 this is no longer the case (not without replacing the entity validator), see NH dev discussion.
I understand the protected requirement, but why internal? This breaks encapsulation, and just feels dirty.
Is the only alternative going back to backing fields?
UPDATE: Embarassing but true, it turns out internal is not required. So, it's a toss-up between falling back to backing fields or using the protected setter and either avoiding setting values in the constructo开发者_高级运维r or facing the risk of hard to track bugs. Thank you Fabio and @Nexus for pointing out my mistake.
Michael,
public string Foo { get; protected set; } should still be possible, the dev discussion is about public string Foo { get; private set; } which can lead to errors while using lazy properties.
NHibernate is quite dirty. It uses reflection in order to access the properties and fields.
You can even map private properties and fields as data points.
NHibernate ignores completely the visibility of the elements it needs to access.
public class Class{
    public string Foo { get; private set; }
}
Property(class=> class.Foo);
You will then need to turn off proxy validation in your configuration:
Config.Proxy(p => {p.Validation = false});
 
         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论