0

有人可以告诉我我在这里做错了什么吗?我试图将列表名称传递给将删除列表中所有行的方法:

    public static void DeleteLastUpdate(Microsoft.SharePoint.Client.List oList)
    {
        using (var context = new ClientContext(FrontEndAppUrl))
        {
            var ss = new System.Security.SecureString();
            Array.ForEach("hhh".ToCharArray(), (c) => { ss.AppendChar(c); });
            context.Credentials = new SharePointOnlineCredentials("yyy", ss);
            var web = context.Web;

            ListItemCreationInformation itemCreateInfo = new ListItemCreationInformation();

            CamlQuery camlQuery = new CamlQuery();
            camlQuery.ViewXml = "<View><Query><OrderBy><FieldRef Name='ID' Ascending='TRUE' /></OrderBy></Query></View>";
            ListItemCollection collListItem = oList.GetItems(camlQuery);
            context.Load(collListItem);

            context.ExecuteQuery();



            foreach (ListItem oListItem in collListItem)
            {

                string i = oListItem["ID"].ToString(); ;

                ListItem ListItemToDelete = oList.GetItemById(i);

                ListItemToDelete.DeleteObject();

                context.ExecuteQuery();

            }

            oList.Update();
        }

    }

    public static void GetCountry()
    {
        using (var context = new ClientContext(FrontEndAppUrl))
        {
            Microsoft.SharePoint.Client.List oList_Country = context.Web.Lists.GetByTitle("LISTNAME");

            DeleteLastUpdate(oList_Country);


        }

    }

我得到的错误是在 context.Load(collListItem);

它说该对象在与与该对象关联的上下文不同的上下文中使用。我还能如何将列表的值传递给 Delete() 方法?

4

2 回答 2

1

异常所说的正是正在发生的事情。您oList_Country在上下文中创建GetCountry(),然后将其传递到DeleteLastUpdate()您在不同上下文中工作的位置。

也许您应该考虑DeleteLastUpdate()通过参数将上下文传递给。然后你的代码会变成这样:

public static void DeleteLastUpdate(ClientContext context, Microsoft.SharePoint.Client.List oList)
{
    // You should not create a context here, but use the supplied context
    // using (var context = new ClientContext(FrontEndAppUrl))
    // {
        var ss = new System.Security.SecureString();
        ...
}

public static void GetCountry()
{
    using (var context = new ClientContext(FrontEndAppUrl))
    {
        Microsoft.SharePoint.Client.List oList_Country = context.Web.Lists.GetByTitle("LISTNAME");

        DeleteLastUpdate(context, oList_Country);  // Pass the context
于 2016-01-20T15:27:17.467 回答
1

我想您可能会尝试在DeleteLastUpdatemethod 中获取的GetCountry方法中重用上下文。顺便说一句DeleteLastUpdate,执行大量查询似乎无效。

于 2016-01-20T15:33:32.157 回答