מאמר זה חל על Microsoft Dynamics ניווט עבור כל המדינות והאזורים כל שפה.

מאפייני הבעיה

בעת שדרוג מסד נתונים מתוך Microsoft Dynamics NAV 2009 ל- Microsoft Dynamics 2013, נתונים היסטוריים בטבלה ארכיון ממד של המסמך לא לשדרג.

פתרון

מידע על תיקונים חמים

תיקון חם נתמך זמין כעת מ- Microsoft. עם זאת, הוא מיועד רק לתיקון הבעיה המתוארת במאמר זה. יש להחיל אותו רק במערכות שהתעוררה בהן בעיה ספציפית זו. תיקון חם זה עשוי לעבור בדיקות נוספות. לכן, אם המערכת שברשותך לא נפגעה באופן חמור מבעיה זו, מומלץ להמתין ל- Microsoft Dynamics NAV 2009 service pack הבאה או גירסת Microsoft Dynamics NAV הבא המכיל תיקון חם זה.

הערה במקרים מיוחדים, שהצגת עבור שיחות עשויים לבטל אם מומחה תמיכה טכנית עבור Microsoft Dynamics ומוצרים קשורים יקבע שעדכון ספציפי יפתור את הבעיה. דמי התמיכה המקובלים יחולו על נוספים שאלות וסוגיות תמיכה אשר אינן מצריכות העדכון הספציפי האמור.



מידע על ההתקנה

מיקרוסופט מציעה דוגמאות תכנות לצורך ההדגמה בלבד, ללא אחריות, בין מפורשת ובין משתמעת. זה כולל, אך אינו מוגבל ל, אחריות מכללא לגבי סחירות או התאמה למטרה מסוימת. מאמר זה מבוסס על ההנחה שאתה מכיר את שפת התכנות המודגמת ובקי בהפעלת הכלים המשמשים ליצירת פרוצדורות ולניפוי שגיאות. מהנדסי התמיכה של Microsoft יכולים לסייע בהסברת הפונקציונליות של פרוצדורה מסוימת, אך הם לא ישנו את הדוגמאות כדי לספק פונקציונליות נוספת או כדי לבנות פרוצדורות שיענו על צרכיך הספציפיים.

הערה לפני התקנת תיקון חם זה, ודא כי כל המשתמשים לקוח Microsoft Navision אינם מחוברים למערכת. זה כולל משתמשים לקוח של שירותי היישום של Microsoft Navision (NAS). אתה אמור להיות לקוח בלבד המשתמש המחובר כאשר ליישם תיקון חם זה.

כדי ליישם תיקון חם זה, דרוש לך רשיון מפתחים.

אנו ממליצים חשבון המשתמש בחלון כניסות Windows או בחלון מסד הנתונים כניסות יוקצו את מזהה תפקיד "סופר". אם חשבון המשתמש אין אפשרות להקצות מזהה תפקיד של "עילי", עליך לוודא כי חשבון משתמש בעל ההרשאות הבאות:

  • שנה את ההרשאה עבור האובייקט שינוי.

  • הרשאת Execute עבור האובייקט 5210 מזהה אובייקט מערכת ועבור האובייקט 9015 מזהה האובייקט של המערכת .



הערה אין לך הרשאות למאגרי נתונים אלא אם כן יש לך לבצע תיקון נתונים.

שינויי קוד

הערה תמיד קוד מחשב פותר בסביבה מבוקרת לפני החלת התיקונים למחשבים הייצור שלך.

כדי לפתור בעיה זו, בצע את הפעולות הבאות:

  1. שנה את הקוד בפונקציה GetTableKeyFieldArray בערך הממד לשדרג - codeunit SQL (104049) באופן הבא:
    קוד קיים

    ...KeyRef := RecRef.KEYINDEX(1);
    IF KeyRef.FIELDCOUNT >= ARRAYLEN(KeyArr) THEN // reserve the last index as 'stop code'
    ERROR(Text013,SQLMgt.GetTableNameSQL(TableID));

    // Delete the following lines.
    FOR i := 1 TO KeyRef.FIELDCOUNT DO BEGIN
    FieldRef := KeyRef.FIELDINDEX(i);
    KeyArr[i,1] := SQLMgt.StringConvert(FieldRef.NAME);
    KeyArr[i,2] := FORMAT(FieldRef.TYPE);
    END;
    // End of the deleted lines.

    RecRef.CLOSE;
    END;
    ...

    קוד החלפה

    ...KeyRef := RecRef.KEYINDEX(1);
    IF KeyRef.FIELDCOUNT >= ARRAYLEN(KeyArr) THEN // reserve the last index as 'stop code'
    ERROR(Text013,SQLMgt.GetTableNameSQL(TableID));

    // Add the following lines.
    IF TableID = DATABASE::"Document Dimension Archive" THEN
    GetDocDimArchiveTableKeyFieldArray(KeyRef,FieldRef,KeyArr)
    ELSE
    FOR i := 1 TO KeyRef.FIELDCOUNT DO BEGIN
    FieldRef := KeyRef.FIELDINDEX(i);
    KeyArr[i,1] := SQLMgt.StringConvert(FieldRef.NAME);
    KeyArr[i,2] := FORMAT(FieldRef.TYPE);
    END;
    // End of the added lines.

    RecRef.CLOSE;
    END;
    ...
  2. שנה את הקוד בפונקציה GetDocDimArchiveTableKeyFieldArray בערך הממד לשדרג - codeunit SQL (104049) באופן הבא:
    קוד קיים

    ...RecRef.CLOSE;
    END;

    LOCAL PROCEDURE AreDimKeyAndParentKeyCompatible@1(OffSet@1000 : Integer) : Boolean;
    VAR
    i@1002 : Integer;
    ...

    קוד החלפה

    ...RecRef.CLOSE;
    END;

    // Add the following lines.
    LOCAL PROCEDURE GetDocDimArchiveTableKeyFieldArray@19(VAR KeyRef@1001 : KeyRef;VAR FieldRef@1000 : FieldRef;VAR KeyArr@1002 : ARRAY [16,2] OF Text[80]);
    VAR
    i@1004 : Integer;
    j@1003 : Integer;
    BEGIN
    FOR i := 1 TO KeyRef.FIELDCOUNT DO BEGIN
    FieldRef := KeyRef.FIELDINDEX(i);
    CASE TRUE OF
    i = 4: j := 6;
    i = 5: j := 4;
    i = 6: j := 5;
    ELSE
    j := i;
    END;
    KeyArr[j,1] := SQLMgt.StringConvert(FieldRef.NAME);
    KeyArr[j,2] := FORMAT(FieldRef.TYPE);
    END
    END;
    // End of the added lines.

    LOCAL PROCEDURE AreDimKeyAndParentKeyCompatible@1(OffSet@1000 : Integer) : Boolean;
    VAR
    i@1002 : Integer;
    ...




דרישות מוקדמות

חייב להיות מותקן כדי להחיל תיקון חם זה 2013 NAV של Microsoft Dynamics.

מידע בדבר הסרת ההתקנה

אין אפשרות להסיר את התיקון החם.

מצב

Microsoft אישרה כי מדובר בבעיה במוצרי Microsoft הרשומים במקטע 'חל על'.

הערה זהו מאמר "פרסום מהיר" שנוצר ישירות בתוך ארגון התמיכה של Microsoft. המידע הכלול במסמך זה מסופק כמו שהוא כתגובה לבעיות המתעוררות. כתוצאה מהמהירות בביצוע כדי להפוך אותו לזמין, החומרים עשויים לכלול שגיאות טיפוגרפיות וייתכן שיבוצעו בהם שינויים בכל עת ללא הודעה מוקדמת. ראה תנאי השימוש שיקולים נוספים.

זקוק לעזרה נוספת?

הרחב את הכישורים שלך
סייר בהדרכה
קבל תכונות חדשות לפני כולם
הצטרף למשתתפי Microsoft insider

האם מידע זה היה שימושי?

עד כמה אתם מרוצים מאיכות השפה?
מה השפיע על החוויה שלכם?

תודה על המשוב!

×