當您從 Microsoft 動態航行點 2009年升級至 [Microsoft 動態 2013年無法升級文件維度封存資料表中的資料

範本︰ CPR-Navision 程式碼修正程式範本

錯誤 #: 188428 (內容維護)

本文適用於 Microsoft 動態航行點的所有國家/地區和所有的語言地區設定。

狀況

當您從 Microsoft 動態航行點 2009年升級資料庫到 Microsoft 動態 2013年時,將無法升級文件維度封存資料表中的記錄資料。

解決方案

Hotfix 資訊

已經可以從 Microsoft 取得支援的 hotfix。不過,它只被用來修正本文所述的問題。它只適用於發生此特定問題的系統上。此 hotfix 可能會接受其他測試。因此,如果此問題不會嚴重影響,我們建議您等候下一步的 Microsoft 動態航行點 2009 service pack 或包含此 hotfix 的下一個 Microsoft 動態航行點版本。

注意 在特殊的情況下,通常會支援呼叫可能已被取消如果技術支援專業人員的 Microsoft 動態及相關的產品所產生的費用會決定某特定更新程式可以解決您的問題。收取支援費用會套用,如果有其他支援問題是,不能限定的特定更新程式。

如果這個 hotfix 沒有公布出來讓公眾下載 (亦即本文中未提供此 hotfix 公開的 URL),則散佈需要技術指導人員、 重大問題小組成員或管理員核准,下列條件︰

  • 接獲此 hotfix,客戶必須遭遇 < 徵狀=""> 一節所述的錯誤。

  • 您必須追蹤您傳送這個檔案,並提供他們下一步的 service pack 時可供使用 (如果 service pack 發佈) 的客戶。

此 hotfix 並未排定隨附於 Microsoft 動態航行點 service pack。



安裝資訊

Microsoft 會提供程式設計範例僅供說明,而不做任何明示或默示的保證。這包括,但不限於適售性或適合某特定用途之默示擔保責任。本文假設您已相當熟悉使用的我們所示範的程式設計語言以及建立和偵錯程序所使用的工具。Microsoft 技術支援工程師可以協助解釋特定程序中,功能,但它們不會修改這些範例以提供附加功能或建構程序來滿足您特定需求。

注意套用此 hotfix 之前,請確認所有的 Microsoft Navision 用戶端使用者會登出系統。這包括 Microsoft Navision 應用程式服務 (NAS) 用戶端的使用者。您應該是唯一的用戶端使用者已登入,當您實作此 hotfix。

若要實作此 hotfix,您必須有開發人員授權。

我們建議您在 Windows 登入] 視窗中的色彩,或資料庫登入] 視窗中的使用者帳戶被指派 「 進階 」 的角色識別碼。如果使用者帳戶不能指派為 「 超級 」 的角色識別碼,您必須確認使用者帳戶具有下列權限︰

  • 您將會變更物件的 [修改] 權限。

  • 執行權限的系統物件 ID 5210物件和系統物件 ID 9015物件。



注意您沒有擁有資料存放區的權限,除非您需要執行資料修復。

程式碼變更

注意永遠測試程式碼修正在受控制的環境中才能套用到實際執行電腦的修正程式。

若要解決這個問題,請依照下列步驟執行︰

  1. 變更 [升級維度資料編輯-SQL codeunit (104049) 的GetTableKeyFieldArray函式中的程式碼如下所示︰
    現有的程式碼

    ...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. 變更 [升級維度資料編輯-SQL codeunit (104049) 的GetDocDimArchiveTableKeyFieldArray函式中的程式碼如下所示︰
    現有的程式碼

    ...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;
    ...




先決條件

您必須套用此 hotfix 之後所安裝的 Microsoft 動態航行點 2013年。

移除資訊

您無法移除此 hotfix。

參考

VSTF DynamicsNAVSE: 347950

狀態

Microsoft 已確認這是<套用>一節所列出的 Microsoft 產品的問題。

注意這是直接從 Microsoft 支援組織內建立的「快速發行」文件。本文件所包含的現狀資訊是針對新興問題的回應。為縮短使其可用的時程,資料可能會包含印刷錯誤,且可能會隨時進行修改而不另行通知。如其他考量,請參閱 「使用規定」。

作者︰ johane
作者︰ v 六
技術編審︰ johane
編輯器︰

Need more help?

Expand your skills
Explore Training
Get new features first
Join Microsoft Insiders

Was this information helpful?

Thank you for your feedback!

×