Hello,
I have a general problem with flowfields in Navision 4.0 with SQL-Server.
THEY ARE TOOOOOO SLOW
data:image/s3,"s3://crabby-images/2449b/2449b0ae56f41c43cb43296a91f4942cfe8ecdfd" alt=":( :("
Especially one problem occurs:
The overall-performance is going down because of the flowfields. Every time I open a form with a table on it wich has many calculated fields it takes a long time to build up the form and to scroll / filter in the table. I tried to build indices, but nothing seems to work. I don't want to redesign the whole application so how can I speed this up ?
It's inexceptably slow!!!!!
Thanks.
Comments
If you need optimize flowfields, you need to create correct keys on the base table (the table from which are the flowfields calculated) - keys with fields with best selectivity which are used in filter of flowfields. If you create such a key (it can be only one field in the key, but may be more to speedup), and the first field in the key will rapidly reduce the range of data needed to read, it will be faster. But if wrong key design lead to that MS SQL server select for example key begining with field of type option or boolean, which have very bad selectivity, you need read for example 50% of table in case of boolean. But if you create key begining for example with customer no., and you are calculating fields per customers, server will read only records for the one customer for which is calculating field and the performance will be better. And do not forget to disable flowfields on work tables (sales lines etc.) because it is faster let MS SQL server calculate the sum than have big SIFT Tables with empty records because deleted documents etc... (if you are not optimizing tables on regulary base)...
MVP - Dynamics NAV
My BLOG
NAVERTICA a.s.
RIS Plus, LLC
No PM,please use the forum. || May the <SOLVED>-attribute be in your title!
I wonder why the C/SIDE can calculate flowfields that fast. My Item table has 20 flowfields and in addition 8 filter fields (I'm NOT the programmer).
But the C/SIDE Server cashes 1000 lines per second (!) while the SQL Server needs 1 second to get only ONE LINE...
So I can't understand this ?!?!
How can the C/SIDE be so fast and the SQL Server so slow ?
In native DB there was no need to optimize the Item table, why now ?
And when I execute a function that goes through all lines in the Item table C/SIDE needs about 1,5 Minutes. SQL Server needs 1 hour for 1 percent!
Optimizing Navision-DB does other things than optimizing SQL-DB.
In short : optimizing Navision-tables is only usefull for tables that don't change a lot. Tables that change a lot (eg. entry-tables) will be faster to read but slower to write, so it's not a good idea to optimize those. Optimizing in SQL is always a good idea.
No PM,please use the forum. || May the <SOLVED>-attribute be in your title!
Becasue SQL Server does not have SIFT (we are hoping that it will be added though, that will solve most of the SQL performance issues), it "mimics" SIFT by keeping bucket values in special key tables. Instead of just 3 values, the DBMS has to read more values than that. How many I don't know, but it's more than the 3 C/SIDE values, and it is in physically separate tables.
RIS Plus, LLC