复制SharePoint列表项(SPListItem)到另一个列表
从理论上讲,有一个简单到难以置信的解决办法:SPListItem提供了一个CopyTo(destinationUrl)方法(可参考MSDN)。不幸的是,这个方法似乎用不了。至少对我的情况(一个带附件的自定义列表)是如此。总是告诉我找不到源列表项,没有读取权限,或者列表没有发布等等。从网上找到很多帖子,其他人也遇到同样的问题。最好的解决方案就是自己实现。
首先设计方法的参数和返回值类型:
|
1
|
public static SPListItem CopyItem(SPListItem sourceItem,string destinationListName) |
内容部分首先是创建目标列表项。然后把源列表项的字段复制到目标项。
|
1
2
3
4
5
6
7
8
9
10
|
//复制sourceItem到destinationListSPList destinationList=sourceItem.Web.Lists(destinationListName);SPListItem targetItem=destinationList.Items.Add();foreach(SPField f in sourceItem.Fields){ if(!f.ReadOnlyField && f.InternalName!="Attachments") { targentItem[f.InternalName]=sourceItem[f.InternalName]; }} |
代码中跳过了只读字段和附件。对于附件我们这样处理:
|
1
2
3
4
5
6
7
8
|
//复制附件foreach(string fileName in sourceItem.Attachments){ SPFile file=sourceItem.ParentList.ParentWeb.GetFile( sourceItem.Attachments.UrlPrefix+fileName); byte[] imageData=file.OpenBinary(); targetItem.Attachments.Add(fileName,imageData);} |
接下来只需提交目标项至数据库并返回即可。
|
1
2
3
|
//保存targetItemtargetItem.Update();return targetItem; |
对该方法的调用方法大致如下:
|
1
|
SPListItem approvedItem=CommonFunctions.CopyItem(item,"目标列表名"); |
为了方便Copy,下面列出完整的代码:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
public static SPListItem CopyItem(SPListItem sourceItem, string destinationListName){ //复制 sourceItem 到 destinationList SPList destinationList = sourceItem.Web.Lists[destinationListName]; SPListItem targetItem = destinationList.Items.Add(); foreach (SPField f in sourceItem.Fields) { if (!f.ReadOnlyField && f.InternalName != “Attachments”) { targetItem[f.InternalName] = sourceItem[f.InternalName]; } } //复制附件 foreach (string fileName in sourceItem.Attachments) { SPFile file = sourceItem.ParentList.ParentWeb.GetFile(sourceItem.Attachments.UrlPrefix + fileName); byte[] imageData = file.OpenBinary(); targetItem.Attachments.Add(fileName, imageData); } targetItem.Update(); return targetItem;} |
对于需要进一步对目标项进行跟踪的情况而言。默认SharePoint的SPListItem带有一个_CopySource字段,并且还有一个对应的CopySource属性。应该是与CopyTo方法配合用的。同样不幸的是都是只读的。没法为我所用。基于这个原因Muhimbi的做法是在目标列表上新建一个自己的字段——_M_CopySource,来实现类似的功能:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
SPList sourceList = MyWorkflow.List;SPList destinationList = MyWorkflow.Web.Lists[MyWorkflow.Parameter1 as String];SPListItem sourceItem = MyWorkflow.Item; // 首先检查自定义的来源字段在目标列表中是否存在if (destinationList.Fields.ContainsField("_M_CopySource") == false){ SPField newField = destinationList.Fields.CreateNewField("Text", "_M_CopySource"); newField.Hidden = true; destinationList.Fields.Add(newField);} // 检查是否存在需要更新的列表项string camlQuery = "<Where>" + "<Eq><FieldRef Name='_M_CopySource'/><Value Type='Text'>{0}</Value></Eq>" + "</Where>";camlQuery = string.Format(camlQuery, sourceItem["FileRef"]);SPQuery query = new SPQuery();query.Query = camlQuery;query.RowLimit = 1; // 查询列表SPListItemCollection items = destinationList.GetItems(query);SPListItem newItem = null;if (items.Count == 0) newItem = destinationList.Items.Add();else newItem = items[0]; // 复制字段foreach(SPField field in sourceItem.Fields){ if (newItem.Fields.ContainsField(field.InternalName) == true && field.ReadOnlyField == false && field.InternalName != "Attachments") { newItem[field.InternalName] = sourceItem[field.InternalName]; }} // 删除目标项上已有的附件for (int i = newItem.Attachments.Count; i > 0; i-- ){ newItem.Attachments.Delete(newItem.Attachments[i-1]);} // 复制所有的附件foreach (string fileName in sourceItem.Attachments){ SPFile file = sourceItem.ParentList.ParentWeb.GetFile(sourceItem.Attachments.UrlPrefix + fileName); byte[] imageData = file.OpenBinary(); newItem.Attachments.Add(fileName, imageData);} // 在目标项上记下复制的来源,以便将来对其进行更新newItem["_M_CopySource"] = sourceItem["FileRef"]; newItem.Update(); |
他是把这段代码用在自定义工作流活动中。实现列表项的单向同步更新。如果在查询中添加上我们自己的条件,就可以实现满足特定条件的更新。确实很有用。
参考资料
SharePoint Listenelement (SPListItem) in eine andere Liste kopieren
Synchronise SharePoint Lists (Calendar/Tasks) using the Workflow Power Pack
复制SharePoint列表项(SPListItem)到另一个列表的更多相关文章
- MFC CListCtrl 将一个列表的选中项添加到另一个列表
MFC CListCtrl 将一个列表的选中项添加到另一个列表, 用VC6.0实现: 简单记录一下自己的学习历程, 和大家分享,如果对你有用,我很高兴. 1.新建一个基于对话框的工程(Dialog-B ...
- Flutter 实战(一):列表项内容可自定义的列表组件
前言 本篇文的目的是熟练掌握 Flutter 组件的封装,并且使用回调函数实现主要功能. 本组件的设计灵感来源于 Element 组件库的 table 组件. 正题 定义回调函数 在此之前,必须要了解 ...
- Python3基础 把一个列表中内容给另外一个列表,形成两个独立的列表
镇场诗:---大梦谁觉,水月中建博客.百千磨难,才知世事无常.---今持佛语,技术无量愿学.愿尽所学,铸一良心博客.------------------------------------------ ...
- 从0开始学FreeRTOS-(列表与列表项)-3
# FreeRTOS列表&列表项的源码解读 第一次看列表与列表项的时候,感觉很像是链表,虽然我自己的链表也不太会,但是就是感觉很像. 在`FreeRTOS`中,列表与列表项使用得非常多 ...
- 从0开始学FreeRTOS-(列表&列表项)-6
# FreeRTOS列表&列表项的源码解读 第一次看列表与列表项的时候,感觉很像是链表,虽然我自己的链表也不太会,但是就是感觉很像. 在FreeRTOS中,列表与列表项使用得非常多,是Free ...
- SharePoint REST API - 列表和列表项
博客地址:http://blog.csdn.net/FoxDave 本篇主要讲述如何用SharePoint REST操作列表和列表项.阅读本篇时请先了解前面讲述的REST介绍和基本操作. 废话不多 ...
- SharePoint 2010 列表项事件接收器 ItemAdded 的使用方法
列表项事件处理器是继承于Microsoft.SharePoint.SPItemEventReceiver的类,Microsoft.SharePoint.SPItemEventReceiver类提供了许 ...
- WPF中反转3D列表项
原文:WPF中反转3D列表项 WPF中反转3D列表项 周银辉记得在苹果电脑中有一个很酷的 ...
- IE问题——列表项图像
等我们实现列表时,经常会遇到一种情况:需要为列表的每一项的前面添加一个列表项图像. 我们在查阅W3C时会发现,在CSS中已经为我们提供了实现方法——“list-style-type”,我们来看看它的实 ...
随机推荐
- 修改Windows Server 2008+IIS 7+ASP.NET默认连接限制,支持海量并发连接数
WIN7中IIS7默认配置的服务器同时最多只能处理5000个请求,如果由于某些情况(程序问题等)造成同时请求超过5000时,将会导致服务器错误.为此,修改服务器的设置,从而支持10万个同时请求. 具体 ...
- hbase基础-系统架构
HBase 系统架构 HBase是Apache Hadoop的数据库,能够对大型数据提供随机.实时的读写访问.HBase的目标是存储并处理大型的数据.HBase是一个开源的,分布式的,多版本的,面向列 ...
- POSTMAN发起请求收到乱码 http 406错误
web前段异常: The resource identified by this request is only capable of generating responses with charac ...
- 详解c++指针的指针和指针的引用(转)
http://www.cnblogs.com/li-peng/p/4116349.html
- [DFNews] Blackbag发布MacQuisition 2013 R2
New in MacQuisition 2013 R2: Improved FileVault 2 Detection - Automatically detect the presence of a ...
- 剖析JavaScript函数作用域与闭包
在我们写代码写到一定阶段的时候,就会想深究一下js,javascript是一种弱类型的编程语言,而js中一个最为重要的概念就是执行环境,或者说作用域.作用域重要性体现在哪呢?首先,函数在执行时会创建作 ...
- Metro Win8风格的按钮(Filp翻转)
原地址->http://www.cnblogs.com/yk250/p/5661093.html 介绍:简约而不简单....颜色可随意调制,最好用Blend工具. 效果图如下:话说这个图会不会太 ...
- IntelliJ IDEA - 代码辅助功能
Eclipse 和 IntelliJ IDEA 都提供了写代码的辅助功能,包括代码补全.代码生成.快速修饰和动态模板等功能. 1. 快速修复(Quick-fixes) 快捷键:Alt+Enter 所有 ...
- opencv 震撼你的视觉-------基础篇
opencv 最近在做一个钓鱼网站的项目中用到了一个叫opencv的玩意儿,以前没接触过.感觉挺新鲜的,而且项目中要用,所以就问了一下度娘(是想Google一下的,显得高大上and专业一点,但是英语水 ...
- iOS各种开源类库
KissXml——xml解析库 相关教程:http://www.iteye.com/topic/625849 http://sencho.blog.163.com/blog/static/830562 ...