CrmService Class 代码,提供基本CRUD,以及RetrieveOptionSet、RetrieveAttribute、GetPickListValue等方法...

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Xrm.Sdk.Client;
using Microsoft.Xrm.Sdk;
using Microsoft.Xrm.Sdk.Query;
using Microsoft.Xrm.Sdk.Messages;
using Microsoft.Xrm.Sdk.Metadata;

namespace MyNameSpace
{
public class CrmService
{
private IOrganizationService _service;
public IOrganizationService Default
{
get { return _service; }
}

public CrmService(IOrganizationService service)
{
_service = service;
}

public Entity RetrieveByQuery(string entityName, string[] columns, bool activeRecordsOnly, LinkEntity[] linkEntities, params ConditionExpression[] condition)
{
QueryExpression qe = new QueryExpression(entityName);
if (columns.Length > 0)
qe.ColumnSet = new ColumnSet(columns);
else
qe.ColumnSet.AllColumns = true;
if (null != condition)
qe.Criteria.Conditions.AddRange(condition);
if (activeRecordsOnly)
qe.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0);
if (null!=linkEntities)
qe.LinkEntities.AddRange(linkEntities);
EntityCollection entityCollect = (EntityCollection)Default.RetrieveMultiple(qe);
if (entityCollect.Entities.Count > 0)
{
return entityCollect.Entities.First();
}
else
{
return null;
}
}

public Entity RetrieveByQuery(string entityName, ColumnSet columns, bool activeRecordsOnly, LinkEntity[] linkEntities, params ConditionExpression[] conditions)
{
QueryExpression qe = new QueryExpression(entityName);
if (null == columns)
qe.ColumnSet.AllColumns = true;
else
qe.ColumnSet = columns;
if (null != conditions)
qe.Criteria.Conditions.AddRange(conditions);
if (activeRecordsOnly)
qe.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0);
if (null!=linkEntities)
qe.LinkEntities.AddRange(linkEntities);
EntityCollection entityCollect = (EntityCollection)Default.RetrieveMultiple(qe);
if (entityCollect.Entities.Count > 0)
{
return entityCollect.Entities.First();
}
else
{
return null;
}
}

public EntityCollection RetrieveMultipleByQuery(string entityName, ColumnSet columns, bool activeRecordsOnly, LinkEntity[] linkEntities, params ConditionExpression[] condition)
{
QueryExpression qe = new QueryExpression(entityName);
if (null == columns)
qe.ColumnSet.AllColumns = true;
else
qe.ColumnSet = columns;
if (null != condition)
qe.Criteria.Conditions.AddRange(condition);
if (activeRecordsOnly)
qe.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0);
if (null != linkEntities)
qe.LinkEntities.AddRange(linkEntities);
EntityCollection entityCollect = (EntityCollection)Default.RetrieveMultiple(qe);
return entityCollect;
}

public EntityCollection RetrieveMultipleByQuery(string entityName, string[] columns, bool activeRecordsOnly, LinkEntity[] linkEntities, params ConditionExpression[] condition)
{
QueryExpression qe = new QueryExpression(entityName);
qe.ColumnSet = new ColumnSet(columns);
if (null != condition)
qe.Criteria.Conditions.AddRange(condition);
if (activeRecordsOnly)
qe.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0);
if (null != linkEntities)
qe.LinkEntities.AddRange(linkEntities);
EntityCollection entityCollect = (EntityCollection)Default.RetrieveMultiple(qe);
return entityCollect;
}

public QueryExpression GetQuery(string entityName, ColumnSet columns, bool activeRecordsOnly, LinkEntity[] linkEntities, params ConditionExpression[] condition)
{
QueryExpression qe = new QueryExpression(entityName);
if (null == columns)
qe.ColumnSet.AllColumns = true;
else
qe.ColumnSet = columns;
if (null != condition)
qe.Criteria.Conditions.AddRange(condition);
if (activeRecordsOnly)
qe.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0);
if (null != linkEntities)
qe.LinkEntities.AddRange(linkEntities);
return qe;
}

public EntityMetadata RetrieveEntity(string entityName)
{
RetrieveEntityRequest req = new RetrieveEntityRequest();
req.LogicalName = entityName;
req.RetrieveAsIfPublished = true;
RetrieveEntityResponse res = (RetrieveEntityResponse)Default.Execute(req);
return res.EntityMetadata;
}

public OptionSetMetadata RetrieveOptionSet(string optionsetName)
{
RetrieveOptionSetRequest req = new RetrieveOptionSetRequest();
req.Name = optionsetName;
req.RetrieveAsIfPublished = true;
RetrieveOptionSetResponse res = (RetrieveOptionSetResponse)Default.Execute(req);
return res.OptionSetMetadata as OptionSetMetadata;
}

public AttributeMetadata RetrieveAttribute(string entityName,string attributeName)
{
RetrieveAttributeRequest req = new RetrieveAttributeRequest();
req.EntityLogicalName = entityName;
req.LogicalName = attributeName;
req.RetrieveAsIfPublished = true;
RetrieveAttributeResponse res = (RetrieveAttributeResponse)Default.Execute(req);
return res.AttributeMetadata;
}

public int GetPickListValueWithPrefix(string entity, string attributeName, string twoDigitValue)
{
PicklistAttributeMetadata attr = (PicklistAttributeMetadata)RetrieveAttribute(entity, attributeName);
OptionMetadata option = new OptionMetadata();
if (attr != null)
{
if (attr.OptionSet != null)
option = attr.OptionSet.Options.ToList().Find(o => o.Value.Value.ToString().EndsWith(twoDigitValue));
}
else
{
throw new InvalidOperationException("Option set not found");
}
if (option != null)
{
if (option.Value.HasValue)
return option.Value.Value;
else
throw new InvalidOperationException("Option " + twoDigitValue + " not found");
}
else
{
throw new InvalidOperationException("Option " + twoDigitValue + " not found");
}
}

public int GetPickListValue(string entity, string attributeName, string label)
{
PicklistAttributeMetadata attr = (PicklistAttributeMetadata)RetrieveAttribute(entity, attributeName);
OptionMetadata option = new OptionMetadata();
if (attr != null)
{
if (attr.OptionSet != null)
option = attr.OptionSet.Options.ToList().Find(o => o.Label.UserLocalizedLabel.Label.ToLower().Equals(label.ToLower()));
}
else
{
throw new InvalidOperationException("Option set not found");
}
if (option != null)
{
if (option.Value.HasValue)
return option.Value.Value;
else
throw new InvalidOperationException("Option " + label + " not found");
}
else
{
throw new InvalidOperationException("Option " + label + " not found");
}
}
}
}

转载于:https://www.cnblogs.com/nixjojo/archive/2012/02/29/2373121.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值