How can I view a No. Series on Report 206?
 
            
                
                    demi222                
                
                    Member Posts: 131                
            
                        
            
                    I have added a new section to Report 206, Sales Invoice Header,Header.
In this header I added a text box... I want to be able to view the
"No. Series Line"."Last No. Used" + 1.
so what I have done:
Global Variables:
NoSeriesLine of type record to the No. Series Line table
NewString of type Code
In the Sales Invoice Header, Header OnPreSection I have written:
NoSeriesLine.GET("Sales Invoice Header"."No. Series");
In the Sales Invoice Header, OnAfterGetRecord I have written:
NewString := INCSTR(NoSeriesLine."Last No. Used");
I added a text box with sourceExpr of NewString.
I get a message:
The No. Series Line does not exist
Identification fields + values:
Series Code := 'S-INV+'
Line No. = '0'
what am I missing?
                In this header I added a text box... I want to be able to view the
"No. Series Line"."Last No. Used" + 1.
so what I have done:
Global Variables:
NoSeriesLine of type record to the No. Series Line table
NewString of type Code
In the Sales Invoice Header, Header OnPreSection I have written:
NoSeriesLine.GET("Sales Invoice Header"."No. Series");
In the Sales Invoice Header, OnAfterGetRecord I have written:
NewString := INCSTR(NoSeriesLine."Last No. Used");
I added a text box with sourceExpr of NewString.
I get a message:
The No. Series Line does not exist
Identification fields + values:
Series Code := 'S-INV+'
Line No. = '0'
what am I missing?
0                
            Comments
- 
            Hi Demi,
 your GET statement is incorrect.
 the primary key for the "no. Series Line" table isSeries Code,Line No. 
 In this table you can setup multiple No.s for the same "No. Series" so you have to identify which one you wish to use.
 As This is not held on the "Sales Header" so you will have to make some kind of rule to specify which you require.
 i.e. ALWAYS use the last no. series line in which case you could then use
 FIND('+');  Remember: Keep it simple0 Remember: Keep it simple0
- 
            ok, I'm a little confused.
 I go to Sales and receivables...Invoices and click on the Posting No. Series. The Last No. Used is the one I want +1.
 If I do:
 IF NoSeriesLine.FIND('+') THEN
 NewString := INCSTR(NoSeriesLine."Last No. Used");
 the same message comes up.
 I don't know where to even find where Line No. is...
 any suggestions?0
- 
            You get the error cause you have a get and a find function working together...
 As "Dean Axon" mentrioned, if you look into the No. Series Line table, the key is "Series Code,Line No." so you either SETRANGE to one of them and perform a find to get ther coresponding records, or you perform a GET with all the key fields provided to the function. Meaning:NoSeriesLine.SETRANGE("Series Code","Sales Invoice Header"."No. Series"); NoSeriesLine.FIND('+'); NewString := INCSTR(NoSeriesLine."Last No. Used");-or-NoSeriesLine.GET("Sales Invoice Header"."No. Series",10000); NewString := INCSTR(NoSeriesLine."Last No. Used");:whistle:0
- 
            ok, an error doesn't show now...
 However, it doesn't show the last no used... in fact, nothing shows up.
 thanks for trying0
- 
            Sourceexpr in your textbox?
 Why do you enable the debugger and place a break point to your code and see where it goes, or do a:MESSAGE(NoSeriesLine."Last No. Used"); MESSAGE(NewString); after your code to see the calculated values.
 :roll:0
- 
            I tried both codes..
 the first one:
 NoSeriesLine.SETRANGE("Series Code","Sales Header"."No. Series");
 NoSeriesLine.FIND('+');
 NewString := INCSTR(NoSeriesLine."Last No. Used");
 This takes the last record from the No. Series Line table and adds 1 to it. However, it is not choosing the correct record. It needs to match with the Posting No. Series chosen.
 The second one:
 NoSeriesLine.GET("Sales Invoice Header"."No. Series",10000);
 NewString := INCSTR(NoSeriesLine."Last No. Used");
 Nothing shows up here.
 I will try the messages that you told me.
 I appreciate all your help... I have spent all day trying to do this... and It won't get done.. 0 0
- 
            Use the Posting No. Series field of "Sales Header":
 NoSeriesLine.SETRANGE("Series Code","Sales Header"."Posting No. Series");
 NoSeriesLine.FIND('+');
 NewString := INCSTR(NoSeriesLine."Last No. Used");0
- 
            I tried it and it didn't work, it still takes the very last record from the
 No. Series Line table... still not the correct record.
 Any other suggestions?0
- 
            Hi Demi,
 the code that Arhontis gave you should work fine :?:
 I tested this :NoSeriesLine.Setrange("Series Code","Sales Invoice Header"."No. Series"); Message(Format(NoSeriesLine.Count));//Just for checking purposes Message("Sales Invoice Header"."No. Series"); NoSeriesLine.Find('+'); NewString:=IncStr(NoSeriesLine."Last No. Used"); Message(NewString);
 I suppose the next question is "What trigger are you placing this code in ?"
 Regards,
 DeanRemember: Keep it simple0
- 
            Exact code if I may say, "Dean Axon", but in demi222's case the report is looking at the sales header and all he wants is to get the propable next number that the sales document will get (Posting No. Series) IF it will be posted. Its a wrong approach if you ask me, since there is uncertainty of the produced INCSTR number, but since the customer wants it and the project manager says ok, somebody has to do it...
 Let me remind to demi that the numbers in No. Series Line table get increased by the "increment-by No." field that might be different from 1 in the INCSTR case. So he could do "increment-by No." times the INCSTR of the NewString to get a more proper number.
 So, the code sould look a bit more like:NoSeriesLine.Setrange("Series Code","Sales Header"."Posting No. Series"); Message(Format(NoSeriesLine.Count));//Just for checking purposes Message("Sales Header"."No. Series"); NoSeriesLine.Find('+'); NewString:=NoSeriesLine."Last No. Used"; FOR i:=1 to NoSeriesLine."Increment-by No." Do NewString:=IncStr(NewString); Message(NewString);
 First of all I would never predict a posting number on a pre-posted document, I guess everybody agrees to that, since there is not number reservations [-o< .
 BTW thanks for the assistance Dean.0
- 
            Thank you BOTH so much for your help!!
 It works just fine... 0 0
- 
            Or, you could do this, and avoid a number of other problems, including NoSeriesLines that haven't been used yet ("Last No. Used" is blank), choosing the correct NoSeriesLine based on date, etc, etc:NxtNumber := NoSeriesMgt.TryGetNextNo("Sales Header"."Posting No. Series",0D);0
Categories
- All Categories
- 73 General
- 73 Announcements
- 66.6K Microsoft Dynamics NAV
- 18.7K NAV Three Tier
- 38.4K NAV/Navision Classic Client
- 3.6K Navision Attain
- 2.4K Navision Financials
- 116 Navision DOS
- 851 Navision e-Commerce
- 1K NAV Tips & Tricks
- 772 NAV Dutch speaking only
- 617 NAV Courses, Exams & Certification
- 2K Microsoft Dynamics-Other
- 1.5K Dynamics AX
- 322 Dynamics CRM
- 111 Dynamics GP
- 10 Dynamics SL
- 1.5K Other
- 990 SQL General
- 383 SQL Performance
- 34 SQL Tips & Tricks
- 35 Design Patterns (General & Best Practices)
- 1 Architectural Patterns
- 10 Design Patterns
- 5 Implementation Patterns
- 53 3rd Party Products, Services & Events
- 1.6K General
- 1.1K General Chat
- 1.6K Website
- 83 Testing
- 1.2K Download section
- 23 How Tos section
- 252 Feedback
- 12 NAV TechDays 2013 Sessions
- 13 NAV TechDays 2012 Sessions


