この資料では、すべての国と言語ロケールのすべての Microsoft Dynamics NAV に該当します。
現象
Dynamics NAV 2013 年、Prepmt を Microsoft Dynamics NAV 2009 からアップグレードする場合VAT 量在庫 (LCY) フィールドは、販売と購買注文明細行ではありません。アップグレードする前に前払請求書が転記され、前払請求書にクレジット メモを作成すると、クレジット メモの前払を転記するときに、不整合メッセージが表示されます。
解決策
修正プログラムの情報
サポートされている修正プログラムはマイクロソフトから現在入手可能です。ただし、この資料に記載されている問題を解決するためのものはのみ。この特定の問題が発生したシステムにのみ適用してください。この修正プログラムは、今後さらにテストを行うことがあります。この問題で深刻な影響を受けていない場合は、次の Microsoft Dynamics NAV 2013 service pack または修正プログラムを含む次の Microsoft Dynamics NAV バージョン待つことを勧めします。
注: かかる料金が免除されるテクニカル サポート担当者 Microsoft Dynamics および関連製品のことは、通常は特別な場合は、特定の更新プログラムは、問題を解決するにを決定します。追加の質問および問題の特定のアップデートの対象にはなりませんが、通常のサポート料金が適用されます。
インストール情報
マイクロソフトでは解説することのみを目的としてプログラミング例を提供しています。暗示あるいは明示していることに対しての保証はしておりません。ここで言う保証とは、特定の目的に対する商品性や適合性の暗示的保証を含んでいますが、それに限定されるわけではありません。この資料では、例示されているプログラミング言語およびプロシージャの作成やデバッグに使用するツールにお客様が精通していることを前提としています。マイクロソフトのサポート エンジニアは、特定のプロシージャの機能について説明することができます。ただし、お客様固有の要件を満たすために、追加機能の提供またはプロシージャの作成のために、これらの例に変更を加えたりはしません。
注: この修正プログラムをインストールする前に、Microsoft Dynamics NAV のすべてのクライアント ユーザーがシステムの電源を記録することを確認します。これには、Microsoft Dynamics NAV アプリケーション サーバー (NAS) のサービスが含まれます。この修正プログラムを実装すると、ログオンしている唯一のクライアント ユーザーが必要です。
この修正プログラムを実装するには、開発者用のライセンスが必要です。
ユーザー アカウントまたはデータベース ログイン ウィンドウに Windows のログイン ウィンドウにある「スーパー」ロール id を割り当てられていることをお勧めします。ユーザー アカウントには、「スーパー」ロール ID を割り当てることができません、する場合は、ユーザー アカウントが次のアクセス許可を持っているを確認する必要があります。
-
変更するオブジェクトの変更のアクセス許可。
-
実行のアクセス許可、システム オブジェクトの ID 5210オブジェクトおよびシステム オブジェクトの ID 9015
オブジェクトです。
注: データの修復を実行する必要があるない限り、データ ストアへの権限を持っている必要はありません。
コードの変更
注: 常にテスト コードを修正、管理された環境で適用する前に、運用コンピューターに修正プログラムします。
この問題を解決するには、次の手順を実行します。
-
次のように、関数のコードのアップグレードアップグレード新しいバージョン Codeunit (104048) でを変更します。
既存のコード...UpdateItemLedgerEntry(StateIndicator);
UpdateDOCreditCard(StateIndicator);
UpdateSalesOrderDate(StateIndicator);
UpdateOutlookSynchFilter(StateIndicator);
UpdateOutlookSynchField(StateIndicator);
DeleteRemovedPermissions(StateIndicator);
...置換用コード
...UpdateItemLedgerEntry(StateIndicator);
UpdateDOCreditCard(StateIndicator);
UpdateSalesOrderDate(StateIndicator);
// Add the following lines.
UpdateSalesLines(StateIndicator);
UpdatePurchLines(StateIndicator);
// End of the added lines.
UpdateOutlookSynchFilter(StateIndicator);
UpdateOutlookSynchField(StateIndicator);
DeleteRemovedPermissions(StateIndicator);
... -
次の関数を追加します。
LOCAL PROCEDURE UpdateSalesLines@62(VAR StateIndicator@1000 : Record 104037);VAR
SalesLine@1001 : Record 37;
LastDocumentNo@1002 : Code[20];
PrepmtInvReminderAmount@1003 : Decimal;
BEGIN
WITH SalesLine DO
IF StateIndicator.UpdateTable(TABLENAME) THEN BEGIN
TimeLog.TimeLogInsert(TimeLog,TABLENAME,TRUE);
SETCURRENTKEY("Document Type","Document No.","Line No.");
IF FINDSET THEN
REPEAT
StateIndicator.Update;
IF ("Document Type" = "Document Type"::Order) AND ("Prepayment Amount" <> "Prepmt. Amt. Incl. VAT") THEN BEGIN
IF "Document No." <> LastDocumentNo THEN BEGIN
LastDocumentNo := "Document No.";
PrepmtInvReminderAmount := 0;
END;
IF ("Prepmt. Amount Inv. (LCY)" <> 0) AND ("Prepmt. VAT Amount Inv. (LCY)" = 0) THEN BEGIN
"Prepmt. VAT Amount Inv. (LCY)" :=
CalcRndedAmount("Prepmt. Amount Inv. (LCY)","Prepayment VAT %" / 100,PrepmtInvReminderAmount);
MODIFY;
END;
END;
UNTIL NEXT = 0;
TimeLog.TimeLogInsert(TimeLog,TABLENAME,FALSE);
StateIndicator.EndUpdateTable(TABLENAME);
END;
LOCAL PROCEDURE UpdatePurchLines@63(VAR StateIndicator@1000 : Record 104037);
VAR
PurchaseLine@1001 : Record 39;
LastDocumentNo@1002 : Code[20];
PrepmtInvReminderAmount@1003 : Decimal;
BEGIN
WITH PurchaseLine DO
IF StateIndicator.UpdateTable(TABLENAME) THEN BEGIN
TimeLog.TimeLogInsert(TimeLog,TABLENAME,TRUE);
IF FINDSET THEN
REPEAT
StateIndicator.Update;
IF ("Document Type" = "Document Type"::Order) AND ("Prepayment Amount" <> "Prepmt. Amt. Incl. VAT") THEN BEGIN
IF "Document No." <> LastDocumentNo THEN BEGIN
LastDocumentNo := "Document No.";
PrepmtInvReminderAmount := 0;
END;
IF ("Prepmt. Amount Inv. (LCY)" <> 0) AND ("Prepmt. VAT Amount Inv. (LCY)" = 0) THEN BEGIN
"Prepmt. VAT Amount Inv. (LCY)" :=
CalcRndedAmount("Prepmt. Amount Inv. (LCY)","Prepayment VAT %" / 100,PrepmtInvReminderAmount);
MODIFY;
END;
END;
UNTIL NEXT = 0;
TimeLog.TimeLogInsert(TimeLog,TABLENAME,FALSE);
StateIndicator.EndUpdateTable(TABLENAME);
END;
LOCAL PROCEDURE CalcRndedAmount@64(LineAmount@1000 : Decimal;Ratio@1001 : Decimal;VAR Reminder@1002 : Decimal) RndedAmount : Decimal;
VAR
Amount@1003 : Decimal;
BEGIN
Amount := Reminder + LineAmount * Ratio;
RndedAmount := ROUND(Amount);
Reminder := Amount - RndedAmount;
END;
必要条件
Microsoft Dynamics NAV 2013 がこの修正プログラムを適用するためにインストールする必要があります。
アンインストール情報
この修正プログラムを削除することはできません。
状況
マイクロソフトは、この問題を「対象製品」セクションに記載されているマイクロソフト製品の問題として認識しています。
注: これは、マイクロソフト サポートの組織内から直接作成した「高速公開」の資料です。ここに含まれる情報は、新たに発生している問題に応じて現状のまま提供されています。速やかに利用できるようにした結果として、内容には誤植が含まれている可能性があり、事前告知なしで改訂する場合があります。その他の考慮事項については、使用条件を参照してください。