2009-09-01 86 views
3

我向UpdateListItems提交更新。它返回成功,但列表项没有更新。有关如何追踪发生问题的任何建议?Sharepoint UpdateListItems列表未更新

下面是所生成的XML:

<Batch OnError='Continue' ListVersion='1' ViewName=''> 
    <Method ID='1' Cmd='Update'> 
     <Field Name='ID'>11707</Field> 
     <Field Name='Business_x0020_Area'>Consumer</Field> 
     <Field Name='Team'>6;#IT Support</Field> 
     <Field Name='Job_x0020_Number'>TEMP</Field> 
     <Field Name='Media_x0020_Outlet2'>13;#BBC Parliament</Field> 
     <Field Name='Publication_x0020_Date'>2009-09-01 14:40:10</Field> 
     <Field Name='Narrative2'></Field> 
     <Field Name='Page_x0020_Number'>1</Field> 
     <Field Name='Media_x0020_Value'></Field> 
     <Field Name='Information_x0020_Only'>0</Field> 
     <Field Name='Date_x0020_Added'></Field> 
    </Method> 
</Batch> 

更新

我在U2U得到的错误是

0x81020014一个或多个字段类型不正确安装。转至列表设置页面以删除这些字段。

+0

你可以张贴的代码片段? – DevinB 2009-09-01 14:23:20

+0

您是否使用C#来处理批处理?您是否使用“ProcessBatchData”功能?如果你是,结果字符串是什么? – DevinB 2009-09-01 15:08:34

+0

我只是在lists.asmx中使用UpdateListItems方法。 – Jack 2009-09-01 15:13:16

回答

2

我在CAML中有一个不在数据库中的内部字段。这导致它绊倒。

0

401表示您未登录,或者您登录的用户对该列表没有权限。确认用户'执行'批处理脚本可以登录到站点并对列表进行更改。

+0

当以用户身份登录时,我可以编辑列表中的项目 – Jack 2009-09-01 14:40:04

+0

此问题是因为我试图更新域外服务器上的列表。在与共享点相同的服务器上,它允许我更新。 – Jack 2009-09-02 11:46:00

+0

酷!感谢更新。您应该为问题添加自己的答案。将其编辑成问题本身,点击底部的“发布答案”。 – DevinB 2009-09-02 12:09:39

1

我的第一个建议是保留字段名称,例如“Business Area”而不是“Business_x0020_Area”。我知道什么时候查找列表xml文件时,字段名称会以这种方式显示。第二个建议是关于你的日期字段。确保你的日期正确。日期字段格式为YYYY-MM-DDTHH:MM:SSZ。 T和Z很重要。我希望它有帮助。

0

我做了这样的事情的日期

public DateTime dateForSp(string s) 
{ 
    string[] sd = s.Split('/'); 
    string[] yd = sd[2].Split(' '); 
    string[] hd = yd[1].Split(':'); 

    DateTime dt = new DateTime(Int32.Parse(yd[0]), 
           Int32.Parse(sd[0]), 
           Int32.Parse(sd[1]), 
           Int32.Parse(hd[0]), 
           Int32.Parse(hd[1]), 
           Int32.Parse(hd[2])); 

    return dt; 
} 

,并在代码

"<Field Name='SubmissionTime'>" + String.Format("{0:u}", dateForSp(this.rProperty["SubmissionTime"])) + "</Field>"