• 直接通过Sharepoint数据库进行取字段信息


    用第三方数据库的数据通过Sharepoint对象模型来取列表的一些字段数据很慢,比如取500条数据,不同站点,不同列表的数据时,要多次执行 site = new SPSite((Guid)reader["SiteId"]);  和  web = site.OpenWeb((Guid)reader["WebId"]);,还去取Item对象  itemById = list.GetItemById(int.Parse(reader["itemid"].ToString()));,

    性能就很差了,速度特别的慢。

    所以只好从Sharepoint数据库入手 ,直接跟Sharepoint 数据做连接。但又遇到一个难题,因为Sharepoint的栏字段 在数据库对应的位置每个列表都一样。从而觉得不好找对应关系,后面发现数据库表 AllLists 中有 tp_Fields这个字段,应该这个字段存储的是栏字段与数据库存储字段的对应关系,通过复制这个字段的信息出来,这个信息是经过压缩的,通过解压方法得到一个XML,这个字段的信息从对象模型也可以得到 splist.Fields.SchemaXml ,得到这个XML后面可以找到栏与数据字段的对应关系了。通过XML对象访问,可以组合成SQL语句的字段,只要用到SQL 中的 CASE WHEN THEN ELSE END 语句,代码如下:

                       SPListCollection splists = SPContext.Current.Web.Lists;
                        string SPdatabase = SPContext.Current.Site.ContentDatabase.Name;            

    string titlecolname = "( CASE a.listid ";

    foreach (SPList splist in splists)
                            {
                                try
                                {
                                    string fieldxml = splist.Fields.SchemaXml;
                                    System.Xml.XmlDocument xmldoc = new System.Xml.XmlDocument();
                                    xmldoc.LoadXml(fieldxml);
                                  
                                    foreach (System.Xml.XmlNode item in xmldoc.GetElementsByTagName("Field"))
                                    {
                                        if (item.Attributes["Name"] != null && item.Attributes["Name"].Value != null && item.Attributes["Name"].Value.ToLower().Trim() == "title")
                                        {
                                            if (item.Attributes["ColName"] != null && !string.IsNullOrEmpty(item.Attributes["ColName"].Value) && (!titlecolnamefl2))
                                            {
                                                titlecolname += " when '" + splist.ID.ToString() + "' then b." + item.Attributes["ColName"].Value;
                                            }
                                        }
                                    }
                                }
                                catch (Exception ex) { }
                            }

                            titlecolname += " ELSE '' END ) as ItemTitle";


  • 相关阅读:
    支付宝沙箱环境应用
    七牛云视频托管
    腾讯云短息验证码接口
    git远程连接(码云)
    git
    字间距
    html文本保留空格
    mysql重启导致AUTO_INCREMENT从1开始
    js保留两位小数
    vue中watch的基本用法
  • 原文地址:https://www.cnblogs.com/netboys/p/2303707.html
Copyright © 2020-2023  润新知