Skip to main content
Solved

Question: Best Practices for refactoring general inquiries to increase performance when joining multiple tables


jcavanagh
Freshman I
Forum|alt.badge.img

Hello, 

At our company, many people need to access the details section of a sales order, as critical for doing our jobs. We have a generic inquiry which pulls data from multiple tables, which impacts performance quite significantly, by taking often 45 seconds or more to load the query. This may not sound like a lot, but when dozens of people run this query dozens of time each day, it creates a lot of friction.

I suspect that there can be significant gains made to performance, with SQL best practices such as not scanning multiple tables, or other system level ways by using lazy loading, database caching, or using a  concurrent thread pool. 

Please direct me to a relevant thread or resource. If not, please respond and I will provide instructions on how to recreate the behavior of the query. 

Efficiency is so key here, because it is one of our largest pain points with the ERP since so many people rely on this general inquiry, it can save the company thousands of dollars each year along with the consternation of having to wait for critical information to load in the ERP.

 

Thank you for reading my post

Best answer by aaghaei

@jcavanagh I guess I misunderestood the original post. My personal experience with GI and API calls when dealing with joined objects is because of the application layer bottleneck. As a programmer if you have ran profiller in your dev environment on Acumatica GIs you possibly have noticed it is really difficult to read the queries generated bu the engine and they are very combursome and the result loaded from the database includes lots of useless fields in the GIs we create. You can try multiple approaches: 

  1. For these heavily used inquiries create your own graph, write the Selects you want and using the Linq limit the filed sets to only those you need, to avoid unnessary load on application.
  2. You may try creating your own projection DACs based on the result set you want and then use the projection DAC in your inquiry but I am not so sure this will be very different than GI itself.
  3. Seems you are developing your internal customizations and not for certification purpose. So a third option that I believe will be the most performance efficient approach is to push the whole load to the Database level. You can create a View by joining the tables (Do NOT forget to add CompanyID join in your query) you need but in the select list only include the fields you need in your GI. Then from this view (Acumatica platform will treat it like a table) auto-create a DAC, append the attributes of the DAC and its fields and then use this DAC in your GI. I believe this will be best performance you can get from the engine.

By the way, shame on those who have let you down by walking away.

View original
Did this topic help you find an answer to your question?

9 replies

aaghaei
Captain II
Forum|alt.badge.img+9
  • Captain II
  • 1178 replies
  • April 8, 2024

@jcavanagh With due respect, this community is meant to gather people around so they can help each other. If you have questions ask your question. If you have prepared something that can benefit others and you are willing to share then share it. I don’t think here is a right place for sales pitches.


jcavanagh
Freshman I
Forum|alt.badge.img
  • Author
  • Freshman I
  • 12 replies
  • April 8, 2024

This isn’t a sales pitch. I’m not selling anything unlike other absentee consultants who’ve left us out to dry in the past by not supporting the code they wrote for us.

I’m looking to improve performance, as a developer, when there clearly is a performance bottleneck in how we constructed one of the general inquiries.


jcavanagh
Freshman I
Forum|alt.badge.img
  • Author
  • Freshman I
  • 12 replies
  • April 8, 2024

It shouldn’t take anywhere near 45 seconds to query several tables if I refactored the general inquiry, which is my hypothesis


aaghaei
Captain II
Forum|alt.badge.img+9
  • Captain II
  • 1178 replies
  • April 8, 2024

Well, if you have tips to share then share. 


jcavanagh
Freshman I
Forum|alt.badge.img
  • Author
  • Freshman I
  • 12 replies
  • April 8, 2024

I’ll follow up with performance bench marking.


Chris Hackett
Community Manager
Forum|alt.badge.img
  • Acumatica Community Manager
  • 2640 replies
  • April 8, 2024

Hi @jcavanagh  - @lauraj46 has done a community webinar on generic inquiries and might be able to offer some advice. You may need to supply further information for her.


jcavanagh
Freshman I
Forum|alt.badge.img
  • Author
  • Freshman I
  • 12 replies
  • April 9, 2024

@Chris Hackett 

 

Thank you for the advice, you’re like a map of Acumatica! I saw her posts and it seems like her brain works in a fascinating way with an intuitive understanding of the data structures.


aaghaei
Captain II
Forum|alt.badge.img+9
  • Captain II
  • 1178 replies
  • Answer
  • April 9, 2024

@jcavanagh I guess I misunderestood the original post. My personal experience with GI and API calls when dealing with joined objects is because of the application layer bottleneck. As a programmer if you have ran profiller in your dev environment on Acumatica GIs you possibly have noticed it is really difficult to read the queries generated bu the engine and they are very combursome and the result loaded from the database includes lots of useless fields in the GIs we create. You can try multiple approaches: 

  1. For these heavily used inquiries create your own graph, write the Selects you want and using the Linq limit the filed sets to only those you need, to avoid unnessary load on application.
  2. You may try creating your own projection DACs based on the result set you want and then use the projection DAC in your inquiry but I am not so sure this will be very different than GI itself.
  3. Seems you are developing your internal customizations and not for certification purpose. So a third option that I believe will be the most performance efficient approach is to push the whole load to the Database level. You can create a View by joining the tables (Do NOT forget to add CompanyID join in your query) you need but in the select list only include the fields you need in your GI. Then from this view (Acumatica platform will treat it like a table) auto-create a DAC, append the attributes of the DAC and its fields and then use this DAC in your GI. I believe this will be best performance you can get from the engine.

By the way, shame on those who have let you down by walking away.


jcavanagh
Freshman I
Forum|alt.badge.img
  • Author
  • Freshman I
  • 12 replies
  • April 9, 2024

Thanks a lot @aaghaei, you are forgiven! I’ll be plugging away at this when I have time, since it’s not my primary responsibility at work, as an analyst. I’ll start with suggestion number 1


Reply


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings