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();
    }
  • 相关阅读:
    爬虫心得
    WSL windows子系统ubuntu18.04建设自己的乌云
    WSL windwos 子系统 ubuntu18.04安装mysql
    python 163 email 554
    Centos 安装Oracle
    JS带进度 文件 重复 自动 异步上传
    xadmin 小组件默认折叠
    grep
    sed
    awk
  • 原文地址:https://www.cnblogs.com/xdanny/p/12395739.html
Copyright © 2011-2022 走看看