מאפייני הבעיה
בעת יצירת חשבונית תשלום מקדמה ב- Microsoft Dynamics NAV 2009, מתקבלת הודעת השגיאה הבאה:
"לא תשלום מקדמה סידרה חייב להיות ערך בכותרת מכירה/רכישה."
מצב זה מתרחש רק אם יש לך לא התקנה סידרת מספרים עבור חשבוניות תשלום מקדמה. בצע את השלבים במקטע קוד שינויים כדי לפתור בעיה זו. בעיה זו מתרחשת במוצרים הבאים:
-
Microsoft Dynamics R2 2009 סרגל ניווט
-
Microsoft Dynamics SP1 2009 סרגל ניווט
פתרון
מידע על תיקונים חמים
תיקון חם נתמך זמין כעת מ- Microsoft. עם זאת, הוא מיועד רק לתיקון הבעיה המתוארת במאמר זה. יש להחיל אותו רק במערכות שהתעוררה בהן בעיה ספציפית זו. תיקון חם זה עשוי לעבור בדיקות נוספות. לכן, אם המערכת שברשותך לא נפגעה באופן חמור מבעיה זו, מומלץ להמתין ל- Microsoft Dynamics NAV 2009 service pack הבאה או גירסת Microsoft Dynamics NAV הבא המכיל תיקון חם זה.
הערה במקרים מיוחדים, שהצגת עבור שיחות עשויים לבטל אם מומחה תמיכה טכנית עבור Microsoft Dynamics ומוצרים קשורים יקבע שעדכון ספציפי יפתור את הבעיה. דמי התמיכה המקובלים יחולו על נוספים שאלות וסוגיות תמיכה אשר אינן מצריכות העדכון הספציפי האמור.
מידע על ההתקנה
מיקרוסופט מציעה דוגמאות תכנות לצורך ההדגמה בלבד, ללא אחריות, בין מפורשת ובין משתמעת. זה כולל, אך אינו מוגבל ל, אחריות מכללא לגבי סחירות או התאמה למטרה מסוימת. מאמר זה מבוסס על ההנחה שאתה מכיר את שפת התכנות המודגמת ובקי בהפעלת הכלים המשמשים ליצירת פרוצדורות ולניפוי שגיאות. מהנדסי התמיכה של Microsoft יכולים לסייע בהסברת הפונקציונליות של פרוצדורה מסוימת. עם זאת, הם לא ישנו את הדוגמאות כדי לספק פונקציונליות נוספת או כדי לבנות פרוצדורות שיענו על צרכיך הספציפיים.
הערה לפני התקנת תיקון חם זה, ודא כי כל המשתמשים לקוח Microsoft Dynamics NAV אינם מחוברים למערכת. זה כולל שירותי Microsoft Dynamics NAV יישום שרת (NAS). אתה אמור להיות לקוח בלבד המשתמש המחובר כאשר ליישם תיקון חם זה.
כדי ליישם תיקון חם זה, דרוש לך רשיון מפתחים.
אנו ממליצים חשבון המשתמש בחלון כניסות Windows או בחלון מסד הנתונים כניסות יוקצו את מזהה תפקיד "סופר". אם חשבון המשתמש אין אפשרות להקצות מזהה תפקיד של "עילי", עליך לוודא כי חשבון משתמש בעל ההרשאות הבאות:
-
שנה את ההרשאה עבור האובייקט שינוי.
-
הרשאת Execute עבור האובייקט 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 R2 2009 סרגל ניווט
-
Microsoft Dynamics SP1 2009 סרגל ניווט
מידע בדבר הסרת ההתקנה
אין אפשרות להסיר את התיקון החם.
מצב
Microsoft אישרה כי מדובר בבעיה במוצרי Microsoft הרשומים במקטע 'חל על'.
הערה זהו מאמר "פרסום מהיר" שנוצר ישירות בתוך ארגון התמיכה של Microsoft. המידע הכלול במסמך זה מסופק כמו שהוא כתגובה לבעיות המתעוררות. כתוצאה מהמהירות בביצוע כדי להפוך אותו לזמין, החומרים עשויים לכלול שגיאות טיפוגרפיות וייתכן שיבוצעו בהם שינויים בכל עת ללא הודעה מוקדמת. ראה תנאי השימוששיקולים נוספים.