zoukankan      html  css  js  c++  java
  • SharePoint中使用Linq出现未将对象引用到实例化的解决方法

    今天在使用Sharepoint的Linq是出现为未将对象引用实例化的问题。在网上一下,发现许多朋友也出现相同的问题。

    问题代码

    using (DataContext ctx = new DataContext(portalUrl))
    {
    EntityList<CustomConfiguration> constConfig = ctx.GetList<EC.Entities.ConstantsConfiguration>("Custom Configuration");
    IList<CustomConfiguration> list=constConfig.ToList();
    }

    程序运行到ToList()的时候就会报错:

    Category: SharePoint Guidance: An exception has occurred.   ExceptionType: 'NullReferenceException'   ExceptionMessage: 'Object reference not set to an instance of an object.'   StackTrace: ' 
    at Microsoft.SharePoint.Linq.SPItemMappingInfo.GetId(SPListItem item, String listName)     
    at Microsoft.SharePoint.Linq.SPItemMappingInfo.MaterializeEntity[TEntity](DataContext dc, SPDataList list, SPListItem item, SPItemMappingInfo itemMappingInfo, JoinPath joinPath) …

    检查发现将DataContext.ObjectTrackingEnabled设为False,再使用ToList()程序就可以通过了。

    正确代码

    using (DataContext ctx = new DataContext(portalUrl))
    {
        ctx.ObjectTrackingEnabled = false;
        EntityList<CustomConfiguration> constConfig = ctx.GetList<EC.Entities.ConstantsConfiguration>("Custom Configuration");
        IList<CustomConfiguration> list=constConfig.ToList();
    }
    

      

    SDK中关于ObjectTrackingEnabled属性的描述:

    Default: true

    gets or sets a value that indicates whether changes in objects are tracked. If this property is false ,changes cannot be persisted to the content database .

    If your code only queries lists, rather than adding, deleting, or editing list items, then you can turn off object change tracking. Doing so will improve performance. Set the ObjectTrackingEnabled property to false.


     

  • 相关阅读:
    JMS基本概念
    SSH项目整合
    SSH框架搭建问题总结
    web项目中classPath指的是哪里?
    web项目中配置文件的加载顺序
    分布式电商系统项目总结
    关于javaweb中图片的存储问题
    商品详情页面的显示
    利用solr实现商品的搜索功能
    SSM框架的搭建与测试
  • 原文地址:https://www.cnblogs.com/snailJuan/p/2475511.html
Copyright © 2011-2022 走看看