设为首页 收藏本站
查看: 437|回复: 0

[经验分享] 【半原创】SharePoint CAML 查询生成器[SharePoint 2010 CAML Query Builder]

[复制链接]
累计签到:4 天
连续签到:1 天
发表于 2015-9-28 13:46:07 | 显示全部楼层 |阅读模式
  这个查询生成器是从SharePoint扒出来的,非完全原创,当然我在它的基础上修改了一下,原来的不支持Text类型的In查询。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using Microsoft.SharePoint;
using System.Globalization;
using Microsoft.SharePoint.Utilities;
namespace Only.SPLibraryExtend.Utils
{
/// <summary>
/// 查询生成器
/// </summary>
public class QueryBuilder
{
/// <summary>
/// 将ID列表转成In操作符的字符串
/// </summary>
/// <param name="lstInIds"></param>
/// <returns></returns>
public static string GetIdsToString(IList<int> lstInIds)
{
string filterIds = "";
foreach (var i in lstInIds)
{
if (filterIds != "")
{
filterIds += ",";
}
filterIds += i.ToString();
}
return filterIds;
}
private static string[] VariantTypeToFieldType = new string[] { SPFieldType.Text.ToString(), SPFieldType.Text.ToString(), SPFieldType.Text.ToString(), SPFieldType.Text.ToString(), SPFieldType.Text.ToString(), SPFieldType.Number.ToString(), SPFieldType.Text.ToString(), SPFieldType.DateTime.ToString(), SPFieldType.Text.ToString(), SPFieldType.Text.ToString(), SPFieldType.Error.ToString(), SPFieldType.Boolean.ToString() };
public QueryBuilder(SPList list)
{
m_splist = list;
WithQueryRootElement = false;
}
private SPList m_splist = null;
public SPList SPList
{
get
{
return m_splist;
}
}
private List<QueryFilterOperation> m_filterOperations = null;
public List<QueryFilterOperation> FilterOperations
{
get
{
if (m_filterOperations == null)
{
m_filterOperations = new List<QueryFilterOperation>();
}
return m_filterOperations;
}
}
/// <summary>
/// 是否需要Query根结点
/// </summary>        
public Boolean WithQueryRootElement
{
get;
set;
}
public string QueryString
{
get
{
XmlDocument document = new XmlDocument();
document.LoadXml("<Query></Query>");
XmlNamespaceManager nsmgr = new XmlNamespaceManager(document.NameTable);
XmlElement query = document.DocumentElement;
System.Xml.XmlNode whereNode = query.SelectSingleNode("Where", nsmgr);
if (whereNode == null)
{
whereNode = document.CreateNode(XmlNodeType.Element, "", "Where", "");
whereNode = query.AppendChild(whereNode);
}
foreach (var operation in this.FilterOperations)
{
string queryField = operation.FieldName;
if ((!string.IsNullOrEmpty(queryField)))
{                        
string filterValue = operation.FilterValue;
bool isLookupId = operation.IsFieldLookupId;
string type = operation.IsFieldLookupId ? "Integer" : null;
string operationTypeName = string.IsNullOrEmpty(operation.OperationType) ? "Eq" : operation.OperationType;
if ((queryField.Length > 0) && (queryField[0] == '@'))
{
queryField = queryField.Substring(1);
}
if (this.SPList != null)
{
SPField internalName = null;
try
{
internalName = this.SPList.Fields.GetFieldByInternalName(queryField);
}
catch (ArgumentException ex)
{
//
}                           
SPFieldCalculated calculated = internalName as SPFieldCalculated;
if (calculated != null)
{
int idx = filterValue.IndexOf('_');
if (idx > 0)
{
ushort typeIdx;
if (ushort.TryParse(filterValue.Substring(0, idx), NumberStyles.None, CultureInfo.InvariantCulture, out typeIdx) && (typeIdx < VariantTypeToFieldType.Length))
{
type = VariantTypeToFieldType[typeIdx];
}
filterValue = filterValue.Substring(idx + 1);
}
}
if (type == null)
{
SPFieldDecimal spDecimal = internalName as SPFieldDecimal;
if ((internalName != null) && ((internalName.Type != SPFieldType.Invalid) || (spDecimal != null)))
{
if (calculated != null)
{
type = calculated.OutputType.ToString();
}
else
{
type = internalName.TypeAsString;
}
if (ReflectorUtils.getPerperty<bool>("IsDateTimeField", internalName))
{
DateTime time;
if (DateTime.TryParse(filterValue, ReflectorUtils.getPerperty<bool>("IsFromConnection", operation) ? CultureInfo.CurrentCulture : CultureInfo.InvariantCulture, DateTimeStyles.None, out time))
{
filterValue = time.ToString("yyyy-MM-ddTHH:mm:ssZ", DateTimeFormatInfo.InvariantInfo);
}
}
else if (spDecimal != null)
{
decimal num;
if (decimal.TryParse(filterValue, NumberStyles.Number, ReflectorUtils.getPerperty<bool>("IsFromConnection", operation) ? CultureInfo.InvariantCulture : CultureInfo.CurrentCulture, out num))
{
filterValue = num.ToString(CultureInfo.InvariantCulture);
}
type = "Text";
}
}
else
{
type = "Text";
}
}
System.Xml.XmlNode firstNode = null;
if (whereNode.FirstChild != null)
{
firstNode = document.CreateNode(XmlNodeType.Element, "", "And", "");
firstNode = whereNode.AppendChild(firstNode);
firstNode.AppendChild(whereNode.FirstChild);
}
else
{
firstNode = whereNode;
}
if (string.IsNullOrEmpty(filterValue))
{
System.Xml.XmlNode nullNode = document.CreateNode(XmlNodeType.Element, "", "IsNull", "");
nullNode = firstNode.AppendChild(nullNode);
System.Xml.XmlNode refNode = document.CreateNode(XmlNodeType.Element, "", "FieldRef", "");
refNode = nullNode.AppendChild(refNode);
XmlAttribute nameAttr = document.CreateAttribute("Name");
nameAttr.Value = queryField;
refNode.Attributes.SetNamedItem(nameAttr);
}
else
{
System.Xml.XmlNode optNode = document.CreateNode(XmlNodeType.Element, "", operationTypeName, "");
optNode = firstNode.AppendChild(optNode);
System.Xml.XmlNode refNode = document.CreateNode(XmlNodeType.Element, "", "FieldRef", "");
refNode = optNode.AppendChild(refNode);
XmlAttribute nameAttr = document.CreateAttribute("Name");
nameAttr.Value = queryField;
refNode.Attributes.SetNamedItem(nameAttr);
if (isLookupId)
{
System.Xml.XmlAttribute lookupAttr = document.CreateAttribute("LookupId");
lookupAttr.Value = "TRUE";
refNode.Attributes.SetNamedItem(lookupAttr);
}
if (operationTypeName == "In")
{
System.Xml.XmlNode valuesNode = document.CreateNode(XmlNodeType.Element, "", "Values", "");
valuesNode = optNode.AppendChild(valuesNode);
if (isLookupId)
{
foreach (string InItem in filterValue.Split(new char[] { ',' }))
{
System.Xml.XmlNode valueNode = document.CreateNode(XmlNodeType.Element, "", "Value", "");
valueNode = valuesNode.AppendChild(valueNode);
nameAttr = document.CreateAttribute("Type");
nameAttr.Value = type;
valueNode.Attributes.SetNamedItem(nameAttr);
filterValue = filterValue.Replace("&5c", @"\");
XmlNode valueText = document.CreateTextNode(InItem);
valueNode.AppendChild(valueText);
}
}
else
{
foreach (string InItem in filterValue.Split(new char[] { ',' }))
{
XmlNode valueNode = document.CreateNode(XmlNodeType.Element, "", "Value", "");
valueNode = valuesNode.AppendChild(valueNode);
nameAttr = document.CreateAttribute("Type");
nameAttr.Value = type;
valueNode.Attributes.SetNamedItem(nameAttr);
filterValue = filterValue.Replace("&5c", @"\");
XmlNode valueText = document.CreateTextNode(filterValue);
valueNode.AppendChild(valueText);
}
}
}
else
{
XmlNode valueNode = document.CreateNode(XmlNodeType.Element, "", "Value", "");
valueNode = optNode.AppendChild(valueNode);
nameAttr = document.CreateAttribute("Type");
nameAttr.Value = type;
valueNode.Attributes.SetNamedItem(nameAttr);
filterValue = filterValue.Replace("&5c", @"\");
XmlNode valueText = document.CreateTextNode(filterValue);
valueNode.AppendChild(valueText);
}
}
}
}
}
if (this.WithQueryRootElement)
{
return document.OuterXml;
}
else
{
return document.DocumentElement.InnerXml;
}
}
}
}

public class QueryFilterOperation
{
private bool m_bIsFromQueryString;
private string m_FilterData;
private string m_FilterValue;
private bool m_IsFieldLookupId;
private bool m_IsFromConnection;
private string m_OperationType;        
public string FieldName
{
get;
set;
}
public string FilterData
{
get
{
return this.m_FilterData;
}
set
{
this.m_FilterData = value;
}
}
public string FilterValue
{
get
{
return this.m_FilterValue;
}
set
{
this.m_FilterValue = value;
}
}
public bool IsFieldLookupId
{
get
{
return this.m_IsFieldLookupId;
}
set
{
this.m_IsFieldLookupId = value;
}
}
internal bool IsFromConnection
{
get
{
return this.m_IsFromConnection;
}
set
{
this.m_IsFromConnection = value;
}
}
internal bool IsFromQueryString
{
get
{
return this.m_bIsFromQueryString;
}
set
{
this.m_bIsFromQueryString = value;
}
}
public string OperationType
{
get
{
return this.m_OperationType;
}
set
{
this.m_OperationType = value;
}
}
}
}

  

  
  调用示例:
//查询单值等于
SPList lst = SPContext.Current.Web.Lists["栏目"];
SPQuery query = new SPQuery();
QueryFilterOperation op = null;
op = new QueryFilterOperation();
op.OperationType = "Eq";
op.FilterValue ="1"
op.FieldName = "NavigationType";
builder.FilterOperations.Add(op);//In查询op = new QueryFilterOperation ();
op.IsFieldLookupId = true;
op.OperationType = "In";
op.FilterValue ="1,2,3,4"
op.FieldName="NavigationType"
builder.FilterOperations.Add(op);//输出查询语句SPQuery query=new SPQuery();
query.Query = builder.QueryString;
var items = lst.GetItems(query);

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-120060-1-1.html 上篇帖子: SharePoint 部署WebPart时 遇到"未能加载文件或程序集"错误 下篇帖子: Sharepoint 2007 Sdk常用基础操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表