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();
    }
  • 相关阅读:
    代码生成器
    怎样成为优秀的软件模型设计者[转]
    2010年部分节假日安排的通知
    Web开发工具整理
    JS模版
    Timer_MinBytesPerSecond,Timer_ConnectionIdle解决办法
    [原]Asp.Net提交后,刷新时事件触发问题解决
    [转]JS日期选择控件
    知道了sa密码,控制服务器
    调试
  • 原文地址:https://www.cnblogs.com/xdanny/p/12395739.html
Copyright © 2011-2022 走看看