3

在我的应用程序中,我正在从列表中创建可观察的集合。列表是我的数据库表的集合。列表显示正确的结果,但是当我创建 observable 集合时,它给了我 Exception as Object reference not set to an instance of an object。当我使用大型数据库运行我的应用程序时,有时会发生这种情况。对于小型数据库,它可以正常工作。

代码:

var list = db.Contacts.ToList();
ObservableCollection collection = new ObservableCollection(list);

例外:

你调用的对象是空的

堆栈跟踪

 at System.Data.Linq.IdentityManager.StandardIdentityManager.InsertLookup(MetaType type, Object instance)
   at System.Data.Linq.CommonDataServices.InsertLookupCachedObject(MetaType type, Object instance)
   at System.Data.Linq.SqlClient.ObjectReaderCompiler.ObjectReaderBase`1.InsertLookup(Int32 iMetaType, Object instance)
   at Read_Contact(ObjectMaterializer`1 )
   at System.Data.Linq.SqlClient.ObjectReaderCompiler.ObjectReader`2.MoveNext()
   at System.Linq.Enumerable.WhereSelectEnumerableIterator`2.MoveNext()
   at System.Linq.Buffer`1..ctor(IEnumerable`1 source)
   at System.Linq.OrderedEnumerable`1.<GetEnumerator>d__0.MoveNext()
   at System.Collections.ObjectModel.ObservableCollection`1.CopyFrom(IEnumerable`1 collection)
   at System.Collections.ObjectModel.ObservableCollection`1..ctor(IEnumerable`1 collection)

目标站点

{System.Object InsertLookup(System.Data.Linq.Mapping.MetaType, System.Object)}

我做错了什么?提前感谢


编辑:

以上只是我代码的一小部分。在我的实际代码中,我使用 UnitOfWork 和存储库模式。为了调试问题,我尝试通过foreach循环打印所有实体的 ID。

  foreach (var item in _uow.Contacts.Query(q => !q.ContactID.Equals(1)))
  {
     i = item.ContactID;
  }

但是突然在一些 25534 (我每次得到随机数字)之后,_uow.Contacts.Query(q => !q.ContactID.Equals(1)无法获得下一个元素。换句话说,不执行 Enumerator.MoveNext()。当然,如果下一个元素是 ,则可能是这样null,但不是。我已将手表添加到列表以确认它。

4

1 回答 1

0

在此代码中,要么db要么Tablesnull

var list = db.Tables.ToList();

确保在之前检查:

if (db != null && ds.Tables != null)
{
var list = db.Tables.ToList();
}
于 2013-07-09T11:15:57.857 回答