CRM で複数のフィールドを動的に結合することは可能ですか?
私が意味するのは、SQLでこのようなものです
select field1, field2, ..., fieldN
from ServiceAppointment
inner join bh_product
on bh_product.bh_contract = ServiceAppointment.bh_product.bh_contract
and bh_product.serviceid = ServiceAppointment.serviceid
queryexpressionを使用して上記の何かを考え出そうとしていますが、必要な動作が得られず、予想よりも多くのレコードが得られます。フィールド番号2の値を事前に知っていればこれを行うことができますが、実行時に何がわからないので、クエリは2つのフィールドを結合する必要があります。私の実際のコードは以下にあり、思いつかない部分を除いています。
これは機能しません... レコードは 2 つしか期待していませんが、数百になります...
var leContact = new LinkEntity(ServiceAppointment.EntityLogicalName, ActivityParty.EntityLogicalName, "activityid", "activityid", JoinOperator.Inner);
leContact.LinkCriteria = new FilterExpression();
leContact.LinkCriteria.AddCondition("partyid", ConditionOperator.Equal, contactId);
queryExpression.LinkEntities.Add(leContact);
result = GetServiceActivityList(queryExpression);
var leService = new LinkEntity(ServiceAppointment.EntityLogicalName, BrightHorizons.Shared.CRM.Interface.Service.EntityLogicalName, "serviceid", "serviceid", JoinOperator.Inner);
queryExpression.LinkEntities.Add(leService);
result = GetServiceActivityList(queryExpression);
// THIS IS THE PROBLEM
var leProduct = new LinkEntity(ServiceAppointment.EntityLogicalName, bh_product.EntityLogicalName, "bh_contract", "bh_contract", JoinOperator.Inner);
var leProduct2 = new LinkEntity(ServiceAppointment.EntityLogicalName, bh_product.EntityLogicalName, "serviceid", "bh_service", JoinOperator.Inner);
queryExpression.LinkEntities.Add(leProduct2);
queryExpression.LinkEntities.Add(leProduct);
result = GetServiceActivityList(queryExpression);
//THIS ALSO DOESNT WORK
var leProduct = new LinkEntity(ServiceAppointment.EntityLogicalName, bh_product.EntityLogicalName, "bh_contract", "bh_contract", JoinOperator.Inner);
leProduct.AddLink(bh_product.EntityLogicalName, "bh_service", "bh_service", JoinOperator.Inner);
queryExpression.LinkEntities.Add(leProduct);
result = GetServiceActivityList(queryExpression);
私は何を間違っていますか?