Συμπτώματα
Όταν δημιουργείτε ένα τιμολόγιο προπληρωμής στο Microsoft Dynamics NAV 2009, λαμβάνετε το ακόλουθο μήνυμα λάθους:
"Προπληρωμή"Όχι ". Σειρά πρέπει να έχει μια τιμή στην κεφαλίδα πωλήσεων/αγορών."
Αυτό συμβαίνει μόνο εάν έχετε ρύθμιση αρίθμηση σειράς για τα τιμολόγια προπληρωμής. Ακολουθήστε τα βήματα της ενότητας οι αλλαγές κώδικα για να επιλύσετε αυτό το ζήτημα. Αυτό το ζήτημα παρουσιάζεται στα ακόλουθα προϊόντα:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 SP1
Προτεινόμενη αντιμετώπιση
Πληροφορίες άμεσης επιδιόρθωσης
Μια υποστηριζόμενη άμεση επιδιόρθωση είναι τώρα διαθέσιμη από τη Microsoft. Ωστόσο, προορίζεται μόνο για τη διόρθωση του ζητήματος που περιγράφεται σε αυτό το άρθρο. Eφαρμόστε τη μόνο σε συστήματα που αντιμετωπίζουν το συγκεκριμένο ζήτημα. Αυτή η επείγουσα επιδιόρθωση ενδέχεται να υποβληθεί σε πρόσθετο έλεγχο. Επομένως, εάν αυτό το ζήτημα δεν σας επηρεάζει ιδιαίτερα, σας συνιστούμε να περιμένετε έως το επόμενο service pack του Microsoft Dynamics NAV 2009 ή την επόμενη έκδοση του Microsoft Dynamics NAV που περιέχει αυτήν την επείγουσα επιδιόρθωση.
Σημείωση Σε ειδικές περιπτώσεις, οι χρεώσεις που υφίστανται κανονικά για κλήσεις υποστήριξης ενδέχεται να να ακυρωθούν, εάν έναν επαγγελματία τεχνικής υποστήριξης για το Microsoft Dynamics και σχετικά προϊόντα προσδιορίζει ότι μια συγκεκριμένη ενημερωμένη έκδοση θα επιλύσει το ζήτημά σας. Οι συνηθισμένες χρεώσεις υποστήριξης θα ισχύει για πρόσθετες ερωτήσεις υποστήριξης και για θέματα που δεν αφορούν τη συγκεκριμένη ενημερωμένη έκδοση.
Πληροφορίες εγκατάστασης
Η Microsoft παρέχει παραδείγματα προγραμματισμού μόνο για επεξήγηση, χωρίς καμία εγγύηση, είτε σιωπηρή είτε ρητή. Αυτό περιλαμβάνει, ενδεικτικά, τις σιωπηρές εγγυήσεις εμπορευσιμότητας ή καταλληλότητας για συγκεκριμένο σκοπό. Αυτό το άρθρο προϋποθέτει ότι είστε εξοικειωμένοι με τη γλώσσα προγραμματισμού που παρουσιάζεται, καθώς και με τα εργαλεία που χρησιμοποιούνται για τη δημιουργία διαδικασιών και τον εντοπισμό σφαλμάτων σε αυτές. Οι μηχανικοί υποστήριξης της Microsoft μπορούν να σας εξηγήσουν τη λειτουργικότητα μιας συγκεκριμένης διαδικασίας. Ωστόσο, δεν θα τροποποιήσουν αυτά τα παραδείγματα για να παράσχουν πρόσθετες λειτουργίες, ούτε θα δημιουργήσουν διαδικασίες για να καλύψουν τις συγκεκριμένες απαιτήσεις σας.
Σημείωση Πριν να εγκαταστήσετε αυτήν την επείγουσα επιδιόρθωση, επιβεβαιώστε ότι όλοι οι χρήστες προγράμματος-πελάτη Microsoft Dynamics NAV έχουν αποσυνδεθεί από το σύστημα. Αυτό περιλαμβάνει υπηρεσίες Microsoft Dynamics NAV εφαρμογών διακομιστή (NAS). Θα πρέπει να το πρόγραμμα-πελάτη μόνο χρήστη που είναι συνδεδεμένος κατά την εφαρμογή αυτής της επείγουσας επιδιόρθωσης.
Για να εφαρμόσετε αυτήν την επείγουσα επιδιόρθωση, πρέπει να έχετε μια άδεια χρήσης του προγραμματιστή.
Συνιστούμε ότι ο λογαριασμός χρήστη στο παράθυρο "Συνδέσεις Windows" ή στο παράθυρο συνδέσεις βάσης δεδομένων να αντιστοιχιστεί το "SUPER" αναγνωριστικό ρόλου. Εάν ο λογαριασμός χρήστη δεν μπορεί να αντιστοιχιστεί το Αναγνωριστικό ρόλου "SUPER", πρέπει να επαληθεύσετε ότι ο λογαριασμός χρήστη έχει τα ακόλουθα δικαιώματα:
-
Το δικαίωμα "Τροποποίηση" για το αντικείμενο που θα αλλάξετε.
-
Τα δικαιώματα εκτέλεσης για το αντικείμενο 5210 Αναγνωριστικό αντικειμένου συστήματος και για την 9015 Αναγνωριστικό αντικειμένου συστήματος
το αντικείμενο.
Σημείωση Δεν πρέπει να έχετε δικαιώματα για τους χώρους αποθήκευσης δεδομένων, εκτός και αν έχετε να εκτελέσετε επιδιόρθωση δεδομένων.
Αλλαγές κώδικα
Σημείωση Πάντα δοκιμή κώδικα διορθώνει σε ελεγχόμενο περιβάλλον πριν να εφαρμόσετε τις ενημερώσεις κώδικα στους υπολογιστές παραγωγής.
Για να επιλύσετε αυτό το ζήτημα, ακολουθήστε τα εξής βήματα:
-
Αλλάξτε τον κωδικό στα πεδία στον πίνακα Επικεφαλίδα Πωλήσεων (36) ως εξής:
Υπάρχοντα κωδικό 1... IF "Prepayment No. Series" <> '' THEN BEGIN
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Delete the following line.
NoSeriesMgt.TestSeries(SalesSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series");
// End of the deleted line.
END;
TESTFIELD("Prepayment No.",'');
END;
...Αντικατάσταση κώδικα 1
...IF "Prepayment No. Series" <> '' THEN BEGIN
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Add the following line.
NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series");
// End of the added line.
END;
TESTFIELD("Prepayment No.",'');
END;
...Υπάρχοντα κώδικα 2
...SalesHeader := Rec;
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Delete the following line.
IF NoSeriesMgt.LookupSeries(SalesSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series") THEN
// End of the deleted line.
VALIDATE("Prepayment No. Series");
Rec := SalesHeader;
END;
...Αντικατάσταση κώδικα 2
...
SalesHeader := Rec;
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Add the following line.
IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series") THEN
// End of the added line.
VALIDATE("Prepayment No. Series");
Rec := SalesHeader;
END;
...Υπάρχοντα κώδικα 3
... IF "Prepmt. Cr. Memo No." <> '' THEN BEGIN
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Delete the following line.
NoSeriesMgt.TestSeries(SalesSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No.");
// End of the deleted line.
END;
TESTFIELD("Prepmt. Cr. Memo No.",'');
END;
...Αντικατάσταση κώδικα 3
... IF "Prepmt. Cr. Memo No." <> '' THEN BEGIN
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Add the following line.
NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series");
// End of the added line.
END;
TESTFIELD("Prepmt. Cr. Memo No.",'');
END;
...Υπάρχοντα κωδικό 4
...SalesHeader := Rec;
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Delete the following lines.
IF NoSeriesMgt.LookupSeries(GetPostingNoSeriesCode,"Prepmt. Cr. Memo No.") THEN
VALIDATE("Prepmt. Cr. Memo No.");
// End of the deleted lines.
Rec := SalesHeader;
END;
END;
...Αντικατάσταση κώδικα 4
...SalesHeader := Rec;
SalesSetup.GET;
SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Add the following lines.
IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series") THEN
VALIDATE("Prepmt. Cr. Memo No. Series");
// End of the added lines.
Rec := SalesHeader;
END;
END;
... -
Αλλάξτε τον κωδικό στη συνάρτηση GetPostingPrepaymentNoSeriesCo στον πίνακα Επικεφαλίδα Πωλήσεων (36) ως εξής:
Υπάρχοντα κώδικα...EXIT(SalesSetup."Posted Invoice Nos.");
END;
LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
VAR
NoSeries@1005 : Record 308;
...Αντικατάσταση κώδικα
... EXIT(SalesSetup."Posted Invoice Nos.");
END;
// Add the following lines.
LOCAL PROCEDURE GetPostingPrepaymentNoSeriesCo@59() : Code[10];
BEGIN
IF "Document Type" IN ["Document Type"::"Return Order","Document Type"::"Credit Memo"] THEN
EXIT(SalesSetup."Posted Prepmt. Cr. Memo Nos.");
EXIT(SalesSetup."Posted Prepmt. Inv. Nos.");
END;
// End of the added lines.
LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
VAR
NoSeries@1005 : Record 308;
... -
Αλλάξτε τον κωδικό στα πεδία στον πίνακα Επικεφαλίδα Αγορών (38) ως εξής:
Υπάρχοντα κωδικό 1...IF "Prepayment No. Series" <> '' THEN BEGIN
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Delete the following line.
NoSeriesMgt.TestSeries(PurchSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series");
// End of the deleted line.
END;
TESTFIELD("Prepayment No.",'');
END;
...Αντικατάσταση κώδικα 1
...IF "Prepayment No. Series" <> '' THEN BEGIN
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Add the following line.
NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series");
// End of the added line.
END;
TESTFIELD("Prepayment No.",'');
END;
...Υπάρχοντα κώδικα 2
...PurchHeader := Rec;
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Delete the following line.
IF NoSeriesMgt.LookupSeries(PurchSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series") THEN
// End of the deleted line.
VALIDATE("Prepayment No. Series");
Rec := PurchHeader;
END;
...Αντικατάσταση κώδικα 2
...PurchHeader := Rec;
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");
// Add the following line.
IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series") THEN
// End of the added line.
VALIDATE("Prepayment No. Series");
Rec := PurchHeader;
END;
...Υπάρχοντα κώδικα 3
...IF "Prepmt. Cr. Memo No. Series" <> '' THEN BEGIN
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Delete the following line.
NoSeriesMgt.TestSeries(PurchSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No. Series");
// End of the deleted line.
END;
// Delete the following line.
TESTFIELD("Prepmt. Cr. Memo No. Series",'');
// End of the deleted line.
END;
OnLookup=BEGIN
...Αντικατάσταση κώδικα 3
...IF "Prepmt. Cr. Memo No. Series" <> '' THEN BEGIN
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Add the following line.
NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series");
// End of the added line.
END;
// Add the following line.
TESTFIELD("Prepmt. Cr. Memo No.",'');
// End of the added line.
END;
OnLookup=BEGIN
...Υπάρχοντα κωδικό 4
...PurchHeader := Rec;
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Delete the following line.
IF NoSeriesMgt.LookupSeries(PurchSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No. Series") THEN
// End of the deleted line.
VALIDATE("Prepmt. Cr. Memo No. Series");
Rec := PurchHeader;
END;
...Αντικατάσταση κώδικα 4
...PurchHeader := Rec;
PurchSetup.GET;
PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");
// Add the following line.
IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series") THEN
// End of the added line.
VALIDATE("Prepmt. Cr. Memo No. Series");
Rec := PurchHeader;
END;
... -
Αλλάξτε τον κωδικό στη συνάρτηση GetPostingPrepaymentNoSeriesCo στον πίνακα Επικεφαλίδα Αγορών (38) ως εξής:
Υπάρχοντα κώδικα...EXIT(PurchSetup."Posted Invoice Nos.");
END;
LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
VAR
NoSeries@1005 : Record 308;
...Αντικατάσταση κώδικα
...EXIT(PurchSetup."Posted Invoice Nos.");
END;
// Add the following lines.
LOCAL PROCEDURE GetPostingPrepaymentNoSeriesCo@37() : Code[10];
BEGIN
IF "Document Type" IN ["Document Type"::"Return Order","Document Type"::"Credit Memo"] THEN
EXIT(PurchSetup."Posted Prepmt. Cr. Memo Nos.");
EXIT(PurchSetup."Posted Prepmt. Inv. Nos.");
END;
// End of the added lines.
LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
VAR
NoSeries@1005 : Record 308;
...
Προϋποθέσεις
Πρέπει να έχετε ένα από τα ακόλουθα προϊόντα, για να εφαρμόσετε αυτήν την επείγουσα επιδιόρθωση:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 SP1
Πληροφορίες κατάργησης
Δεν μπορείτε να καταργήσετε αυτήν την επείγουσα επιδιόρθωση.
Κατάσταση
Η Microsoft έχει επιβεβαιώσει ότι πρόκειται για ένα ζήτημα των προϊόντων της Microsoft που παρατίθενται στην ενότητα "Ισχύει για".
Σημείωση Αυτό είναι ένα άρθρο "ΤΑΧΕΙΑΣ ΔΗΜΟΣΙΕΥΣΗΣ" που έχει δημιουργηθεί απευθείας από την εταιρεία υποστήριξης της Microsoft. Οι πληροφορίες που περιέχονται στο παρόν έγγραφο παρέχονται ως έχουν, ως απάντηση σε ζητήματα που προέκυψαν. Ως αποτέλεσμα της ταχύτητας διαθεσιμότητάς του, το υλικό ενδέχεται να περιλαμβάνει τυπογραφικά λάθη και μπορεί να αναθεωρηθεί οποιαδήποτε στιγμή, χωρίς προειδοποίηση. Για άλλα θέματα, ανατρέξτε στην ενότητα " Όροι χρήσης".