I am using NHibernate 2.0.1 and .NET I am facing issues with Lazy loading an association
I have a BusinessObject class that has associations to other BusinessObject in it, and it can go deeper.
The following function is in the BusinessObject to read the values of a collection in the BusinessObject.
public virtual object GetFieldValue(string fieldName)
{
var fieldItems = fieldName.Split(AppConstants.DotChar);
var objectToRead = this;
for (var i = 0; i < fieldItems.Length - 1; i++)
{
objectToRead = (BusinessObject) objectToRead.GetFieldValue(fieldItems[i]);
}
//if (objectToRead._data == null) return objectToRead.SystemId + " Error: _data was null";
return objectToRead.FieldValue(fieldName.LastItem());
}
The FieldValue
function is described below
private object FieldValue(string fieldName)
{
return _data.Contains(fieldName) ? _data[fieldName] : null;
}
The BusinessObject
has a dictionary_data
which stores the field values.
Assume the fieldName is BusinessDriver.Description
and the BusinessObject which has this field is StrategyBusinessDriver
This code breaks down the field name into two - BusinessDriver
& Description
.
The first iteration reads the BusinessDriver
object from StrategyBusinessDriver
.
It is cast into a BusinessObject
type so that I can call the GetFieldValue
again on it to read the next field i.e Description
in the BusinessDriver
.
The problem is that when I read the BusinessDriver
in the first iteration and cast it, I get the Ids and all other details of the BusinessObject but the field dictionary _data
and other collections are not fetched. This should be fetched lazily when I read the _data of the BusinessObject.
However, this does not happen and I get an error that _data is null.
Is there something wrongly coded because of which the collection is not fetched lazily? Please ask for more clarifications if needed. Thanks in advance.
UPDATE: I have some more insight into the problem. The code to load the fields of the BusinessObject is not lazily loaded if the function is called recursively inside the BusinessObject. If I move this logic out of the BusinessObject, lazy loading works! Is there a way for this to work inside the BusinessObject?
UPDATE: Mapping file
<joined-subclass name="Japt.Core.Domain.Data.BusinessObject, Japt.Core, Version=0.0.1608.0, Culture=neutral, PublicKeyToken=null" table="BusinessObject_BusinessDriverStrategyMap" entity-name="BusinessDriverStrategyMap">
<key column="SystemId" />
<dynamic-component name="_data" insert="true" update="true" optimistic-lock="true">
<many-to-one class="Japt.Core.Domain.Data.BusinessObject, Japt.Core, Version=0.0.1608.0, Culture=neutral, PublicKeyToken=null" name="Strategy" entity-name="Strategy">
<column name="Strategy" />
</many-to-one>
<many-to-one class="Japt.Core.Domain.Data.BusinessObject, Japt.Core, Version=0.0.1608.0, Culture=neutral, PublicKeyToken=null" name="BusinessDriver" entity-name="BusinessDriver">
<column name="BusinessDriver" />
</many-to-one>
</dynamic-component>
<dynamic-component name="_collections" insert="true" update="true" optimistic-lock="true" />
</joined-subclass>