让我们假设以下集合:
<list name="Items" inverse="true" cascade="all-delete-orphan" lazy="extra">
<key column="ItemId"/>
<index column="Sortorder" />
<one-to-many class="MyProject.Model.Item, MyProject"/>
</list>
最初是lazy="true"
,但我想提高效果。只要有物品,这个效果很好。如果没有,则以下语句将生成System.InvalidCastException: Object cannot be cast from DBNull to other types.
:
if (items.Count > 0) { // Type of items: IList<item>
这确实适用于lazy="true"
。我在这里缺少什么?
sl3dg3
编辑:整个堆栈跟踪:
[InvalidCastException: Object cannot be cast from DBNull to other types.]
System.DBNull.System.IConvertible.ToInt32(IFormatProvider provider) +56
System.Convert.ToInt32(Object value) +28
NHibernate.Persister.Collection.AbstractCollectionPersister.GetSize(Object key, ISessionImplementor session) +334
NHibernate.Collection.AbstractPersistentCollection.ReadSize() +132
NHibernate.Collection.PersistentList.get_Count() +12
MyProject.Provider.MyProvider.SomeMethod() in [...]
第二次编辑:
如果我使用调试器打开集合,则会有来自源mscorelib
的HResult,听起来好像错误已经出现在.com世界的深处......
答案 0 :(得分:0)
从我看到的“items”可能为null,您尝试对null值执行Count()。在尝试Count()
之前,最好检查它是否为null