套用到
Dynamics NAV 2009 Dynamics NAV 2009 Service Pack 1

快速發佈文件提供直接從 Microsoft 的支援組織內的資訊。在此處包含的資訊建立的新興或唯一的主題,或要補充知識庫 」 中的其他資訊。

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

狀況

如果廠商上的權衡方式是負 Microsoft 動態航行點 2009 Service Pack 1] 中,「 建議的供應商付款 」 報表 (393) 會建議負的餘額為付款。

解決方案

Hotfix 資訊

已經可以從 Microsoft 取得支援的 hotfix。不過,它只被用來修正本文所述的問題。它只適用於發生此特定問題的系統上。此 hotfix 可能會接受其他測試。因此,如果此問題不會嚴重影響,我們建議您等候下一步的 Microsoft 動態航行點 2009 service pack 或包含此 hotfix 的下一個 Microsoft 動態航行點版本。注意 在特殊的情況下,通常會支援呼叫可能已被取消如果技術支援專業人員的 Microsoft 動態及相關的產品所產生的費用會決定某特定更新程式可以解決您的問題。收取支援費用會套用,如果有其他支援問題是,不能限定的特定更新程式。

安裝資訊

Microsoft 會提供程式設計範例僅供說明,而不做任何明示或默示的保證。這包括,但不限於適售性或適合某特定用途之默示擔保責任。本文假設您已相當熟悉使用的我們所示範的程式設計語言以及建立和偵錯程序所使用的工具。Microsoft 技術支援工程師可以協助解釋特定程序中,功能,但它們不會修改這些範例以提供附加功能或建構程序來滿足您特定需求。注意套用此 hotfix 之前,請確認所有的 Microsoft Navision 用戶端使用者會登出系統。這包括 Microsoft Navision 應用程式服務 (NAS) 用戶端的使用者。您應該是唯一的用戶端使用者已登入,當您實作此 hotfix。若要實作此 hotfix,您必須有開發人員授權。我們建議您在 Windows 登入] 視窗中的色彩,或資料庫登入] 視窗中的使用者帳戶被指派 「 進階 」 的角色識別碼。如果使用者帳戶不能指派為 「 超級 」 的角色識別碼,您必須確認使用者帳戶具有下列權限︰

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

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

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

程式碼變更

注意永遠測試程式碼修正在受控制的環境中才能套用到實際執行電腦的修正程式。若要解決這個問題,請依照下列步驟執行:

  1. 變更 「 建議的供應商付款 」 報表 (393) 中的廠商-OnPostDataItem觸發程序中的程式碼如下所示︰現有的程式碼

    ...   IF FIND('-') THEN     REPEAT       Window.UPDATE(1,"No.");       PayableVendLedgEntry.SETRANGE("Vendor No.","No.");       GetVendLedgEntries(TRUE,TRUE);       GetVendLedgEntries(FALSE,TRUE);       CheckAmounts(TRUE);       UNTIL (NEXT = 0) OR StopPayments;  END;  ClearNegative;  JnlLineDim.LOCKTABLE;...

    取代程式碼

    ...   IF FIND('-') THEN     REPEAT       Window.UPDATE(1,"No.");       PayableVendLedgEntry.SETRANGE("Vendor No.","No.");       GetVendLedgEntries(TRUE,TRUE);       GetVendLedgEntries(FALSE,TRUE);       CheckAmounts(TRUE);       ClearNegative;     UNTIL (NEXT = 0) OR StopPayments;  END ELSE   IF FIND('-') THEN     REPEAT       ClearNegative;     UNTIL NEXT = 0;  JnlLineDim.LOCKTABLE;...
  2. 變更 「 建議的供應商付款 」 報表 (393) 中的GetVendLedgEntries程序中的程式碼如下所示︰現有的程式碼

    ...  VendLedgEntry.RESET;  VendLedgEntry.SETCURRENTKEY("Vendor No.",Open,Positive,"Due Date");  VendLedgEntry.SETRANGE("Vendor No.",Vendor."No.");  VendLedgEntry.SETRANGE(Open,TRUE);  VendLedgEntry.SETRANGE(Positive,Positive);  IF Future THEN BEGIN...

    取代程式碼

    ...  VendLedgEntry.RESET;  VendLedgEntry.SETCURRENTKEY("Vendor No.",Open,Positive,"Due Date");  VendLedgEntry.SETRANGE("Vendor No.",Vendor."No.");  VendLedgEntry.SETRANGE(Open,TRUE);  VendLedgEntry.SETRANGE(Positive,Positive);  VendLedgEntry.SETRANGE("Applies-to ID",'');  IF Future THEN BEGIN...
  3. 變更 「 建議的供應商付款 」 報表 (393) 中的MakeGenJnlLines程序中的程式碼如下所示︰現有的程式碼

    ...      Window.UPDATE(1,VendLedgEntry."Vendor No.");      TempPaymentBuffer.INSERT;    END;    VendLedgEntry.TESTFIELD("Applies-to ID",'');    VendLedgEntry."Applies-to ID" := TempPaymentBuffer."Document No.";  END ELSE BEGIN...

    取代程式碼

    ...      Window.UPDATE(1,VendLedgEntry."Vendor No.");      TempPaymentBuffer.INSERT;    END;    VendLedgEntry."Applies-to ID" := TempPaymentBuffer."Document No.";  END ELSE BEGIN...
  4. 變更 「 建議的供應商付款 」 報表 (393) 中的ClearNegative程序中的程式碼如下所示︰現有的程式碼

    ...      WHILE PayableVendLedgEntry.NEXT <> 0 DO BEGIN        TempCurrency.Code := PayableVendLedgEntry."Currency Code";        CurrencyBalance := 0;        PayableVendLedgEntry2 := PayableVendLedgEntry;        IF TempCurrency.INSERT THEN BEGIN          PayableVendLedgEntry.SETRANGE("Currency Code",PayableVendLedgEntry."Currency Code");          REPEAT            CurrencyBalance := CurrencyBalance + PayableVendLedgEntry."Amount (LCY)"          UNTIL PayableVendLedgEntry.NEXT = 0;          IF CurrencyBalance < 0 THEN            PayableVendLedgEntry.DELETEALL;        END;        PayableVendLedgEntry.SETRANGE("Currency Code");        PayableVendLedgEntry := PayableVendLedgEntry2;      END;...

    取代程式碼

    ...      WHILE PayableVendLedgEntry.NEXT <> 0 DO BEGIN        TempCurrency.Code := PayableVendLedgEntry."Currency Code";        CurrencyBalance := 0;        IF TempCurrency.INSERT THEN BEGIN          PayableVendLedgEntry2 := PayableVendLedgEntry;          PayableVendLedgEntry.SETRANGE("Currency Code",PayableVendLedgEntry."Currency Code");          REPEAT            CurrencyBalance := CurrencyBalance + PayableVendLedgEntry."Amount (LCY)"          UNTIL PayableVendLedgEntry.NEXT = 0;          IF CurrencyBalance < 0 THEN            PayableVendLedgEntry.DELETEALL;          PayableVendLedgEntry.SETRANGE("Currency Code");          PayableVendLedgEntry := PayableVendLedgEntry2;        END;      END;...

先決條件

您必須擁有 Microsoft 動態航行點 2009 Service Pack 1 安裝套用此 hotfix 之後。

移除資訊

您無法移除此 hotfix。

狀態

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

MICROSOFT 和/或其供應商做任何表示或擔保適用性、 可靠性或包含資訊的正確性的相關文件中,並為任何目的發行此 WEB 站台 (「 材料 」) 的相關的圖形。內資料可能包含技術錯誤或印刷錯誤,以及可能會修訂,在任何時候,不另行通知。相關法律所允許之最大範圍內,MICROSOFT 和/或其供應商不,並排除所有的表示法、 保證、 和條件,不論明示、 默示或法定,包括但不是限於表示、 擔保及標題、 未侵權、 令人滿意的條件或品質、 適售性以及適合某特定用途,相對於內資料的條件。

需要更多協助嗎?

想要其他選項嗎?

探索訂閱權益、瀏覽訓練課程、瞭解如何保護您的裝置等等。