代码改变世界

Tech·Ed 2008见闻之-实战经验:编写高质量高效率的SharePoint应用程序

2008-11-08 08:29  Virus-BeautyCode  阅读(533)  评论(2编辑  收藏  举报
昨天有幸参加了微软的Tech·Ed 2008年会,见到很多的牛人,包括大名鼎鼎的鞠海洋等MVP,鞠海洋的讲演果然很是吸引人,很有鼓动性,听起来很有劲的。
还有园子里面的老赵,赵劼 ,老赵,听了他的MVC在ASP.NET Web应用程序中的应用,虽然还没有开始学习MVC,但是也很是收益。
感谢这么多的MVP给我们带来的精彩课程。

因为最近一直在研究sharepoint,所以着重听了sharepoint的课程,这里主要是对听到的两堂sharepoint课程做一个小小的总结。
第一堂是来自美国总部的企业顾问“宋泽惟”的课程

实战经验:编写高质量高效率的SharePoint应用程序

这里我的标题就借用了他的课程名称,希望没有知识产权的问题,如果有的话,我会尽快修改的。

首先是SOM(Sharepoint Object Model )中的陷阱

1、资源管理方面的陷阱

不好意思了,有事出去一下,回来继续总结,要是博客园提供一个草稿箱就好了,可以先保存起来

哈哈,看到几位的回复了,真是对不住大家了,现在来继续我的总结吧。

资源管理方面的一个陷阱就是说
SPSite和SPWeb
SPSite site=new SPSite("http://localhost");
SPWeb web
=site.OpenWeb();

相信这两句是每一个写sharepoint开发的人都会写的,可是就在这两句中就有一个大陷阱,是什么呢,就是这两个对象是非托管的对象,是需要明确释放的,释放的两种方式为:
1、using
2、try。。。catch。。。finally。。。
但是呢,有两个意外,那就是
SPSite site= SPContext.Current.Site;
SPWeb web
=SPContext.Current.Web;
从SPContext,也就是sharepoint的上下文中获取的这两个对象是托管对象,可以不用显示释放。

二、低效的删除陷阱

SPList list;
            
foreach(SPListItem item in list.Items)
            {
                list.Items.DeleteItemById();
                
            }
这一段循环删除lsit中的items,效率很低的,在演示中,删除一条大概要半秒多,大家有兴趣可以尝试一下的。

那么什么是高效的删除操作呢,就是用
SPWeb web;
  web.ProcessBatchData();
spweb中的批处理方法,效率要高300%多呢,详细代码如下:
代码引用自
http://www.cnblogs.com/laputa-sky/archive/2008/10/21/1299867.html

Deleting a large number of items from a list in SharePoint 
From :http:
//blog.thekid.me.uk/archive/2007/02/24/deleting-a-considerable-number-of-items-from-a-list-in-sharepoint.aspx

 

 

Recently the question was asked 
in the newsgroups about deleting a large number of items from SharePoint (WSS) in the fastest way. I had, in one if my projects, needed to remove a large number of item from SharePoint and the best way I found was to use 'ProcessBatchData' as it avoided the API and was considerably faster. 

Here 
is some example code which will remove items from a SharePoint list. If you do this I would remember about the Recycle Bin and the effect deleting many items will have in the futureit maybe worth adding some code which also removes the items from the recycle bin once it has finished. 

StringBuilder sbDelete 
= new StringBuilder();
sbDelete.Append(
"<?xml version=\"1.0\" encoding=\"UTF-8\"?><Batch>");

foreach (SPListItem item in CurrentList.Items)
{
    sbDelete.Append(
"<Method>");
    sbDelete.Append(
"<SetList Scope=\"Request\">" + CurrentList.ID + "</SetList>");
    sbDelete.Append(
"<SetVar Name=\"ID\">" + Convert.ToString(item.ID) + "</SetVar>");
    sbDelete.Append(
"<SetVar Name=\"Cmd\">Delete</SetVar>");
    sbDelete.Append(
"</Method>");
}

sbDelete.Append(
"</Batch>");

try
{
    SPContext.Current.Site.RootWeb.ProcessBatchData(sbDelete.ToString());
}
catch (Exception ex)
{
    Console.WriteLine(
"Delete failed: " + ex.Message);
    
throw;


I took me some time to re
-find this code and so I have posted it here more for my benefit, but if anyone finds it useful then great. 

三、低效的查询,

SPList list;
   foreach(SPListItem item in list.Items)
   {
    if(item["name"]=="virus")
    {
     
     Console.WriteLine("yes");
    }
    
   }
像这样的循环查找,除非你的列表中只有很少的记录,要不就使用SPQuery,上面的做法会导致返回全部的对象,所有效率很低,有时候效率低,不是因为sharepoint本身的问题,而是我们选择了错误的方法。
SPQuery的最大缺陷就是不支持联合查询,也就是sql中的join,不知道下一个版本会不会实现这个很好用的功能呢。

四、得到list的item的数量
可能我们都习惯了
list.Items.Count
这样的效率也是非常低下的,因为他会返回alllitem,这是设计问题,但是微软提供了
list.ItemCount;
这个属性同样是返回count,但是却没有了上面的问题,建议大家使用。

还有啊,这个版本还有一个2000限制,就是说一个应用最好不要超过2000个网站,一个网站不要最好超过2000个列表,一个列表下面最好不要超过2000个item,超过之后性能会急剧下降,但是不是致命的,超过2000,微软建议建立文件夹来分类存放,当前版本的列表也支持文件夹了吗。

另外的一节课是候钟雷和杜伟的自定义列的开发,主要的意义还在于扩展了我们的开发思路,列不仅仅是一个单行文本或者日期输入之类的东西了,而是可以看做一个对象,然后这个对象又是一个复杂的输入。
比如说在场地订阅功能中,自定义一个冲突检测列,就是一个验证函数,用来验证场地的订阅日期和已经存在的时间有无冲突。还可以表现一个主子表的内容,就是说可以是一个SPGridView控件,来显示详细表的内容,然后还可以编辑。微软的权限可以控制到条目级,但是列可以定义是否可以,是否可以编辑,估计下一版会丰富到栏目级吧。

看来思路的扩展还是很重要的,需要我们通过实践和时间来积累,大家可以一起来研究SharePoint的应用开发,我的MSN:jorden008@hotmail.com,我们共同进步,共同MVP。
哈哈!!