cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
gmanuki
Frequent Visitor

Web API or fetchXML to get count of records

Hi I want to get a count of contact records displayed on screen as information and was wondering should i use fetchXML or the WEB API to achieve this. Any examples would be great 🙂

 

Thanks Gary

1 ACCEPTED SOLUTION

Accepted Solutions
dgoode
MPP
MPP

Hi Gary,

 

 You could leverage the Web API or use a regular liquid Fetch XML statement. If you need perform create, update or delete actions then leverage the web API. If you are only doing read, it may be easier to just create a web template that uses some liquid fetch XML. Below is the documentation of the web api and an example tutroial from docs.

 

https://docs.microsoft.com/en-us/power-apps/maker/portals/read-operations

https://docs.microsoft.com/en-us/power-apps/maker/portals/webapi-tutorial

 

 

Below is an example I put together just using liquid fetch xml. I think this may suffice for your needs.

Web Template:

 

{% if user %}
  Hello, {{ user.fullname }}!
{% endif %}
<p>This is an example of using fetchXml and Liquid to query data in CRM from the Portal:</p>
{% fetchxml my_query %}
<fetch version="1.0" output-format="xml-platform" mapping="logical" distinct="false">
  <entity name="contact">
    <attribute name="fullname" />
    <attribute name="telephone1" />
    <attribute name="contactid" />
    <order attribute="fullname" descending="false" />
    <filter type="or">
      <condition attribute="fullname" operator="like" value="%Tom%" />
      <condition attribute="fullname" operator="like" value="%Kevin%" />
      <condition attribute="fullname" operator="like" value="%Meg%" />
    </filter>
  </entity>
</fetch>
{% endfetchxml %}
 
<p><b>The FetchXml used in the query is:</b> {{ my_query.xml | escape }}</p><br/>
<p><b>The total number of records returned is:</b>{{ my_query.results.record_count }}</p><br/>
<p><b>The property that indicates if there are more records than the maximum (50) returned is:</b> {{ my_query.results.more_records }}</p><br/>
<p><b>The paging cookie that you use to page through a list of records is:</b> {{ my_query.results.paging_cookie | escape }}</p>
<p><b>This is where you loop through the records returned and build your table or list or anything you would like to do with the collection of records returned</b></p>
<table>
  <tr>
     <th>Contact Id</th>
     <th></th>
     <th>Contact Name</th>
  </tr>
{% for result in my_query.results.entities %}
  <tr>
    <td>{{ result.id | escape }}</td>
    <td>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</td>
    <td>{{ result['fullname'] | escape }}</td>
    <td>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</td>
    <td>{{ result['telephone1'] | escape }}</td>
  </tr>
{% endfor %}
<table>

 

 

Then just link it to a Page Template, then to a web page and you’re done.

 

Here’s how it will look:

 

dgoode_1-1654712787388.png

 

The total number of records returned is: The property that indicates if there are more records than the maximum (50) returned is: false The paging cookie that you use to page through a list of records is:

View solution in original post

9 REPLIES 9
dgoode
MPP
MPP

Hi Gary,

 

 You could leverage the Web API or use a regular liquid Fetch XML statement. If you need perform create, update or delete actions then leverage the web API. If you are only doing read, it may be easier to just create a web template that uses some liquid fetch XML. Below is the documentation of the web api and an example tutroial from docs.

 

https://docs.microsoft.com/en-us/power-apps/maker/portals/read-operations

https://docs.microsoft.com/en-us/power-apps/maker/portals/webapi-tutorial

 

 

Below is an example I put together just using liquid fetch xml. I think this may suffice for your needs.

Web Template:

 

{% if user %}
  Hello, {{ user.fullname }}!
{% endif %}
<p>This is an example of using fetchXml and Liquid to query data in CRM from the Portal:</p>
{% fetchxml my_query %}
<fetch version="1.0" output-format="xml-platform" mapping="logical" distinct="false">
  <entity name="contact">
    <attribute name="fullname" />
    <attribute name="telephone1" />
    <attribute name="contactid" />
    <order attribute="fullname" descending="false" />
    <filter type="or">
      <condition attribute="fullname" operator="like" value="%Tom%" />
      <condition attribute="fullname" operator="like" value="%Kevin%" />
      <condition attribute="fullname" operator="like" value="%Meg%" />
    </filter>
  </entity>
</fetch>
{% endfetchxml %}
 
<p><b>The FetchXml used in the query is:</b> {{ my_query.xml | escape }}</p><br/>
<p><b>The total number of records returned is:</b>{{ my_query.results.record_count }}</p><br/>
<p><b>The property that indicates if there are more records than the maximum (50) returned is:</b> {{ my_query.results.more_records }}</p><br/>
<p><b>The paging cookie that you use to page through a list of records is:</b> {{ my_query.results.paging_cookie | escape }}</p>
<p><b>This is where you loop through the records returned and build your table or list or anything you would like to do with the collection of records returned</b></p>
<table>
  <tr>
     <th>Contact Id</th>
     <th></th>
     <th>Contact Name</th>
  </tr>
{% for result in my_query.results.entities %}
  <tr>
    <td>{{ result.id | escape }}</td>
    <td>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</td>
    <td>{{ result['fullname'] | escape }}</td>
    <td>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</td>
    <td>{{ result['telephone1'] | escape }}</td>
  </tr>
{% endfor %}
<table>

 

 

Then just link it to a Page Template, then to a web page and you’re done.

 

Here’s how it will look:

 

dgoode_1-1654712787388.png

 

The total number of records returned is: The property that indicates if there are more records than the maximum (50) returned is: false The paging cookie that you use to page through a list of records is:

Thanks for your response i was thinking this would be the best for simple counts

 

Thanks Garry

@dgoode 

So what happens if i have more than fifty records. How do i return the exact count ?

Fubar
Multi Super User
Multi Super User

If all you are after is a count of records then you need to adjust your FetchXML to be an aggregate and return 1 row (rather than try to return all results and count the returned results). see: https://docs.microsoft.com/en-us/power-apps/developer/data-platform/use-fetchxml-aggregation

 

Edit: also, the decision to use Liquid or Web API should be driven by how your Web Page needs the data.  Liquid is server-side code and will run as part of the process runs before sending the Web Page to your Browser, Web API is client-side and pulls the data after the Web Page has loaded.   There are scenarios where either is valid, but often Liquid is the best choice.

adedapo
Helper V
Helper V

@Fubar Please can you elaborate on how to get the result an maybe an example of the fetchxml query. I've been trying to figure is out for some time now.

 

Thanks

adedapo
Helper V
Helper V

@Fubar yeah I was able to eventually solve it after much trial and errors 😅

Hi i am using the fetch query it does not returns any records, I tried adding those extra configuration to fetch page metadata you mentioned above for some reason i noticed the query it returns is partial and not full 

 

Fetch query 

<fetch version="1.0" output-format="xml-platform" mapping="logical" distinct="false">
  <entity name="contact">
    <attribute name="fullname" />
    <attribute name="emailaddress1" />
    <attribute name="parentcustomerid" />
    <attribute name="telephone1" />
    <attribute name="statecode" />
    <attribute name="contactid" />
    <attribute name="firstname" />
  </entity>
</fetch>

 

Result on page. Not sure why the query is coming partially only and no results on page. 

 

image.png

 

 

Helpful resources

Announcements

Celebrating the May Super User of the Month: Laurens Martens

@LaurensM  is an exceptional contributor to the Power Platform Community. Super Users like Laurens inspire others through their example, encouragement, and active participation. We are excited to celebrated Laurens as our Super User of the Month for May 2024.   Consistent Engagement:  He consistently engages with the community by answering forum questions, sharing insights, and providing solutions. Laurens dedication helps other users find answers and overcome challenges.   Community Expertise: As a Super User, Laurens plays a crucial role in maintaining a knowledge sharing environment. Always ensuring a positive experience for everyone.   Leadership: He shares valuable insights on community growth, engagement, and future trends. Their contributions help shape the Power Platform Community.   Congratulations, Laurens Martens, for your outstanding work! Keep inspiring others and making a difference in the community!   Keep up the fantastic work!    

Check out the Copilot Studio Cookbook today!

We are excited to announce our new Copilot Cookbook Gallery in the Copilot Studio Community. We can't wait for you to share your expertise and your experience!    Join us for an amazing opportunity where you'll be one of the first to contribute to the Copilot Cookbook—your ultimate guide to mastering Microsoft Copilot. Whether you're seeking inspiration or grappling with a challenge while crafting apps, you probably already know that Copilot Cookbook is your reliable assistant, offering a wealth of tips and tricks at your fingertips--and we want you to add your expertise. What can you "cook" up?   Click this link to get started: https://aka.ms/CS_Copilot_Cookbook_Gallery   Don't miss out on this exclusive opportunity to be one of the first in the Community to share your app creation journey with Copilot. We'll be announcing a Cookbook Challenge very soon and want to make sure you one of the first "cooks" in the kitchen.   Don't miss your moment--start submitting in the Copilot Cookbook Gallery today!     Thank you,  Engagement Team

Announcing Power Apps Copilot Cookbook Gallery

We are excited to share that the all-new Copilot Cookbook Gallery for Power Apps is now available in the Power Apps Community, full of tips and tricks on how to best use Microsoft Copilot as you develop and create in Power Apps. The new Copilot Cookbook is your go-to resource when you need inspiration--or when you're stuck--and aren't sure how to best partner with Copilot while creating apps.   Whether you're looking for the best prompts or just want to know about responsible AI use, visit Copilot Cookbook for regular updates you can rely on--while also serving up some of your greatest tips and tricks for the Community. Check Out the new Copilot Cookbook for Power Apps today: Copilot Cookbook - Power Platform Community.  We can't wait to see what you "cook" up!      

Tuesday Tip | How to Report Spam in Our Community

It's time for another TUESDAY TIPS, your weekly connection with the most insightful tips and tricks that empower both newcomers and veterans in the Power Platform Community! Every Tuesday, we bring you a curated selection of the finest advice, distilled from the resources and tools in the Community. Whether you’re a seasoned member or just getting started, Tuesday Tips are the perfect compass guiding you across the dynamic landscape of the Power Platform Community.   As our community family expands each week, we revisit our essential tools, tips, and tricks to ensure you’re well-versed in the community’s pulse. Keep an eye on the News & Announcements for your weekly Tuesday Tips—you never know what you may learn!   Today's Tip: How to Report Spam in Our Community We strive to maintain a professional and helpful community, and part of that effort involves keeping our platform free of spam. If you encounter a post that you believe is spam, please follow these steps to report it: Locate the Post: Find the post in question within the community.Kebab Menu: Click on the "Kebab" menu | 3 Dots, on the top right of the post.Report Inappropriate Content: Select "Report Inappropriate Content" from the menu.Submit Report: Fill out any necessary details on the form and submit your report.   Our community team will review the report and take appropriate action to ensure our community remains a valuable resource for everyone.   Thank you for helping us keep the community clean and useful!

Hear what's next for the Power Up Program

Hear from Principal Program Manager, Dimpi Gandhi, to discover the latest enhancements to the Microsoft #PowerUpProgram, including a new accelerated video-based curriculum crafted with the expertise of Microsoft MVPs, Rory Neary and Charlie Phipps-Bennett. If you’d like to hear what’s coming next, click the link below to sign up today! https://aka.ms/PowerUp    

Welcome! Congratulations on joining the Power Pages community!

Welcome to the Power Pages Community!   You're now a part of a vibrant group of peers and industry experts who are here to network, share knowledge, and even have a little fun.     Now that you're a member, you can enjoy the following resources:   The Power Pages Community Forums The forums are also a great place to connect with other Power Pages community members. Check the News & Announcements section for community highlights, find out about the latest community news, and learn about the Community Team. Share your feedback, earn custom profile badges, enter challenges to win prizes, and more.   Community Blog Our community members have learned some excellent tips and have keen insights on the future of business analysis. Head on over to the Community Blog to read the latest posts from around the world. Let us know if you'd like to become an author and contribute your own writing — everyone is welcome.   And that’s not all, we have Galleries of additional information such as the Community Connections & How To Videos & Webinars & Video Gallery and more to motivate, educate and inspire you.   Again, welcome to the Power Pages community family, we are so happy you have joined us! Whether you are brand new to the world of data or you are a seasoned veteran - our goal is to shape the community to be your ‘go to’ for support, networking, education, inspiration and encouragement as we enjoy this adventure together! Let us know in the Community Feedback forum if you have any questions or comments about your community experience, but for now – head on over to the forums Get Help with Power Pages and dive right in!   To learn more about the community and your account be sure to visit our Community Support Area. We look forward to seeing you in the Power Pages Community!   The Power Pages Community Team  

Top Kudoed Authors
Users online (2,993)