zoukankan      html  css  js  c++  java
  • 更新查询项lookup value in list using CSOM

    public void UpdateLookup(string siteUrl, int id, string lookupColumnName,
    List multiLookupValues, string listName, string lookupListName)
    {
        using (ClientContext ctx = new ClientContext(siteUrl))
        {
            ctx.Credentials = new NetworkCredential(_username, _password, _domain);
            var list = ctx.Web.Lists.GetByTitle(listName);
            var item = list.GetItemById(id);
            var lookUpList = ctx.Web.Lists.GetByTitle(lookupListName);
            CamlQuery query = new CamlQuery();
            query.ViewXml = CreateCaml(multiLookupValues);
            var items = lookUpList.GetItems(query);
            ctx.Load(item, i => i[lookupColumnName]);
            ctx.Load(items);
            ctx.ExecuteQuery();
            var lookupValues = new ArrayList();
            FieldLookupValue[] values = item[lookupColumnName] as FieldLookupValue[];
            foreach (ListItem listItem in items)
            {
                var lookupValue = new FieldLookupValue { LookupId = listItem.Id };
                lookupValues.Add(lookupValue);
            }
            item.ParseAndSetFieldValue(lookupColumnName, null);
            item.Update();
            item[lookupColumnName] = lookupValues.ToArray();
            item.Update();
            ctx.ExecuteQuery();
        }
    }


    public void UpdateLookup(string siteUrl, int id, string lookupColumnName,
    List multiLookupValues, string listName, string lookupListName)
    {
        using (ClientContext ctx = new ClientContext(siteUrl))
        {
            ctx.Credentials = new NetworkCredential(_username, _password, _domain);
            var list = ctx.Web.Lists.GetByTitle(listName);
            var item = list.GetItemById(id);
            var lookUpList = ctx.Web.Lists.GetByTitle(lookupListName);
            CamlQuery query = new CamlQuery();
            query.ViewXml = CreateCaml(multiLookupValues);
            var items = lookUpList.GetItems(query);
            ctx.Load(item, i => i[lookupColumnName]);
            ctx.Load(items);
            ctx.ExecuteQuery();
            var lookupValues = new ArrayList();
            FieldLookupValue[] values = item[lookupColumnName] as FieldLookupValue[];
            foreach (ListItem listItem in items)
            {
                var lookupValue = new FieldLookupValue { LookupId = listItem.Id };
                lookupValues.Add(lookupValue);
            }
            item.ParseAndSetFieldValue(lookupColumnName, null);
            item.Update();
            item[lookupColumnName] = lookupValues.ToArray();
            item.Update();
            ctx.ExecuteQuery();
        }
    }
    private string CreateCaml(List multiLookupValues)
    {
        if (multiLookupValues.Count == 1)
        {
            return string.Format(@"
     
                    {0}
     
              ", multiLookupValues[0]);
        }
        StringBuilder sb = new StringBuilder();
        sb.Append(@"
     
                                ");
     
        foreach (string multiLookupValue in multiLookupValues)
        {
            sb.Append(string.Format(@"
     
                     {0}
                      ", multiLookupValue));
        }
        sb.Append(@"
     
                     ");
        return sb.ToString();
    }
  • 相关阅读:
    条款33:避免遮掩继承而来的名称
    LeetCode OJ:Combinations (排列组合)
    LeetCode OJ:Delete Node in a Linked List(链表节点删除)
    LeetCode OJ:Contains Duplicate III(是否包含重复)
    LeetCode OJ:Contains DuplicateII(是否包含重复II)
    luogu 1004 方格取数
    平衡树之伸展树(Splay Tree)题目整理
    P2472 [SCOI2007]蜥蜴(网络最大流)
    P1349 广义斐波那契数列(矩阵加速)
    P4113 [HEOI2012]采花 (莫队TLE)
  • 原文地址:https://www.cnblogs.com/xdanny/p/12395739.html
Copyright © 2011-2022 走看看