Search code examples
dynamics-crmdynamics-crm-4dynamics-crm-2011fetchxml

FetchXML OR Condition


I have a FetchXML query and I have it so if participationtypemask equals 5 than it puts the users with a participationtypemask of 5 in the Required Column. But I also want to add it so if a user has a participationtypemask of 6 then it puts those users in the Optional column. Is this even possible in FetchXML? This is what I have so far.

<fetch>
      <entity name="appointment">
        <attribute name="scheduledstart" />
        <link-entity name="systemuser" from="systemuserid" to="ownerid" link-type="outer">
            <attribute name="firstname" alias="ownerFirstName" />
            <attribute name="lastname" alias="ownerLastName" />
        </link-entity>
        <link-entity name="contact" from="contactid" to="new_contactperson" link-type="outer">
            <attribute name="parentcustomerid" alias="parentaccount" />
            <attribute name="new_businessunit" alias="businessunit" />
        </link-entity>
        <attribute name="new_contactperson" />
        <attribute name="subject" />
        <attribute name="new_coldernotes" />
    <link-entity name="activityparty" from="activityid" to="activityid" link-type="outer">
    <attribute name="participationtypemask" alias="participationtypemask" />
        <filter>
        <condition attribute="participationtypemask" operator="eq" value="5" />
        </filter>
        <link-entity name="contact" from="contactid" to="partyid" link-type="outer">
            <attribute name="firstname" alias="RequiredContactFirstName" />
            <attribute name="lastname" alias="RequiredContactLastName" />
        </link-entity>
        <link-entity name="systemuser" from="systemuserid" to="partyid" link-type="outer">
            <attribute name="fullname" alias="RequiredOwners" />
        </link-entity>
        <link-entity name="account" from="accountid" to="partyid" link-type="outer">
            <attribute name="name" alias="RequiredAccount" />
        </link-entity>
    </link-entity>
        <filter type="and">
            <condition attribute="scheduledstart" operator="on-or-after" value="@FromDate" />
            <condition attribute="scheduledstart" operator="on-or-before" value="@ToDate" />
        </filter>
      </entity>
</fetch>

Solution

  • I personally have been busy, so sorry for the longer wait, but I think all you should have to do is make another join to the link-entity Activity Party with the appropriate aliases, as below.

    <fetch>
      <entity name="appointment">
        <attribute name="scheduledstart" />
        <link-entity name="systemuser" from="systemuserid" to="ownerid" link-type="outer">
          <attribute name="firstname" alias="ownerFirstName" />
          <attribute name="lastname" alias="ownerLastName" />
        </link-entity>
        <link-entity name="contact" from="contactid" to="new_contactperson" link-type="outer">
          <attribute name="parentcustomerid" alias="parentaccount" />
          <attribute name="new_businessunit" alias="businessunit" />
        </link-entity>
        <attribute name="new_contactperson" />
        <attribute name="subject" />
        <attribute name="new_coldernotes" />
        <link-entity name="activityparty" from="activityid" to="activityid" link-type="outer">
          <attribute name="participationtypemask" alias="participationtypemask" />
          <filter>
            <condition attribute="participationtypemask" operator="eq" value="5" />
          </filter>
          <link-entity name="contact" from="contactid" to="partyid" link-type="outer">
            <attribute name="firstname" alias="RequiredContactFirstName" />
            <attribute name="lastname" alias="RequiredContactLastName" />
          </link-entity>
          <link-entity name="systemuser" from="systemuserid" to="partyid" link-type="outer">
            <attribute name="fullname" alias="RequiredOwners" />
          </link-entity>
          <link-entity name="account" from="accountid" to="partyid" link-type="outer">
            <attribute name="name" alias="RequiredAccount" />
          </link-entity>
        </link-entity>
        <!--the new join-->
        <link-entity name="activityparty" from="activityid" to="activityid" link-type="outer" alias="optionalactivityparty">
          <attribute name="participationtypemask" alias="optionalparticipationtypemask" />
          <filter>
            <condition attribute="participationtypemask" operator="eq" value="6" />
          </filter>
          <link-entity name="contact" from="contactid" to="partyid" link-type="outer" alias="optionalcontact">
            <attribute name="firstname" alias="OptionalContactFirstName" />
            <attribute name="lastname" alias="OptionalContactLastName2" />
          </link-entity>
          <link-entity name="systemuser" from="systemuserid" to="partyid" link-type="outer" alias="systemuser2">
            <attribute name="fullname" alias="OptionalOwners" />
          </link-entity>
          <link-entity name="account" from="accountid" to="partyid" link-type="outer" alias="optionalaccount">
            <attribute name="name" alias="OptionalAccount" />
          </link-entity>
        </link-entity>
        <filter type="and">
          <condition attribute="scheduledstart" operator="on-or-after" value="@FromDate" />
          <condition attribute="scheduledstart" operator="on-or-before" value="@ToDate" />
        </filter>
      </entity>
    </fetch>