AutoSplitKey problem

Hi,

I'm still new to NAV...

I would like to change the sorting of page 1007 ("Job Planning Lines) to be "Job No.,Job Task No.,Planning Date, Line No." descending. So I add "Planning Date" in the primary key of table 1003 ("Job Planning Lines") and add the key on page 1007 property SourceTableView and setting it to "Descending".

It works fine, but when the user presses "New", NAV shows the error "The lines cannot be split".

How do I sort the lines the way I want, without causing problems for the "New" functionallity?

Best Answer

Answers

  • Slawek_GuzekSlawek_Guzek Member Posts: 1,690
    Do not change the primary key on any table without knowing exactly what are you doing and what are the consequences of your action. That rule, by the way, applies not only to NAV, but to any application.

    Why didn't you just click the Planning Date on the Job Planning Lines page when you needed them to be displayed in the Planning Date order?



    Slawek Guzek
    Dynamics NAV, MS SQL Server, Wherescape RED;
    PRINCE2 Practitioner - License GR657010572SG
    GDPR Certified Data Protection Officer - PECB License DPCDPO1025070-2018-03
  • MortenSteengaardMortenSteengaard Member Posts: 136
    The customer is tired of always clicking on the column header "Planning Date" whenever she opens the window.
  • Slawek_GuzekSlawek_Guzek Member Posts: 1,690
    edited 2018-11-20
    You do not need to modify any key on the Job Planning Lines table to achieve that (not even mentioning the PK change). Just set the desired sorting order in PageView property, or add a line of code with SETCURRENKEY to the OnOpen page trigger

    Having said that - this is a prime example of when to say NO to customer's request to modify the system. What if you have another user in future, also using Planning Lines, and they want different default display order, because they are also "too tired to make one click"?

    If you don't learn to decline such requests you will soon end up developing one big green button titled 'Guess what I want and do everything for me", which will have to be mind-activated (well one click is too tiresome for some users) and will have a system which is heavily modified, hard to understand, maintain, and keep up to date with patches released from Microsoft,
    Slawek Guzek
    Dynamics NAV, MS SQL Server, Wherescape RED;
    PRINCE2 Practitioner - License GR657010572SG
    GDPR Certified Data Protection Officer - PECB License DPCDPO1025070-2018-03
  • MortenSteengaardMortenSteengaard Member Posts: 136
    I totally agree with you, but I need to make this work, which I can't.

    In the OnOpenPage trigger, I write this:

    SETCURRENTKEY("Job No.","Job Task No.","Planning Date","Line No.");
    SETASCENDING("Planning Date", FALSE);

    NAV totally ignores the "SETASCENDING"-line. I have tried with TRUE and FALSE and with other fields, but there is no change in my page.

    (My changes to SETCURRENTKEY is visible on the page.)

    I need the "Planning Date" to be descending.
  • MortenSteengaardMortenSteengaard Member Posts: 136
    After "SETASCENDING..." I have this:

    IF FINDFIRST THEN;

    I can see that the FINDFIRST finds a different record when the SETASCENDING is FALSE compared to when SETASCENDING is TRUE. So I get some sorting.

    But the problem is that in every case, the lines are shown in the same order (with the oldest on top). I need the newest "Planning Date" to be on top.
  • whynotwiwhynotwi Member Posts: 20
    I agree with Slawek, that the users have a lot of wishes, but often it is not really senseful to fulfil this wishes. But ok, sometimes there is a higher power that says "Do this !" and you have to follow...

    Changing a primary key is always a bad idea. At least until you haven't identified every GET-Action on the database to this record...

    Is it possible to add a new key ? If so, add a key to the fields you want and use SETCURRENTKEY when opening the page. Then the order is in the field(s) you have choosen in the SETCURRENTKEY-function.
  • MortenSteengaardMortenSteengaard Member Posts: 136
    Now I have tried to add a new key ("Job No.","Job Task No.","Planning Date","Line No.") on the table.

    And I still have this code in the OnOpenPage trigger:

    SETCURRENTKEY("Job No.","Job Task No.","Planning Date","Line No.");
    SETASCENDING("Planning Date", FALSE);
    IF FINDFIRST THEN;

    In the page, all records have the same "Job No." and "Job Task No." - at least in my test case. And it still shows the smallest/oldest "Planning Date" as the first record on top.

  • Slawek_GuzekSlawek_Guzek Member Posts: 1,690
    You do not need to add any new key to the table.

    Put "SORTING(Planning Date) ORDER(Descending)" in the SourceTableView property, and add IF FINDSET() THEN; to the OnOpenPage trigger.
    Slawek Guzek
    Dynamics NAV, MS SQL Server, Wherescape RED;
    PRINCE2 Practitioner - License GR657010572SG
    GDPR Certified Data Protection Officer - PECB License DPCDPO1025070-2018-03
  • MortenSteengaardMortenSteengaard Member Posts: 136
    I have that now and now the page is fine. But when I press the "New" button, I get the error message: "The lines cannot be split". The error message turn up on every line except when I am on the topmost line.
  • whynotwiwhynotwi Member Posts: 20
    @Slawek: ok, its offtopic, but doesn't the SourceTableView require a key ? In my mind the SourceTableView is the same as SETCURRENTKEY, just as a property (and mayvbe a little faster than that).
  • Slawek_GuzekSlawek_Guzek Member Posts: 1,690
    @whynotwi No. SourceTableView and SETCURRENTKEY did require a key in versions pre 2013, now they do not.

    By the way the SourceTableView and SETCURRENTKEY should act exactly in the same way, but apparently there is some bug in NAV causing the SETCURRENTKEY to be ignored
    Slawek Guzek
    Dynamics NAV, MS SQL Server, Wherescape RED;
    PRINCE2 Practitioner - License GR657010572SG
    GDPR Certified Data Protection Officer - PECB License DPCDPO1025070-2018-03
  • MortenSteengaardMortenSteengaard Member Posts: 136
    Hi Slawek.

    Thank you very much for your explanation! I learned a lot.

    I won't change the page.

    Best regards,

    Morten
Sign In or Register to comment.