この資料では、すべての国と言語ロケールのすべての Microsoft Dynamics NAV に該当します。
現象
アプリケーションのワークシートを使用して、Microsoft Dynamics NAV 2009 年に、平均原価計算メソッドを使用しているアイテムのエントリを再適用することを想定しています。在庫評価レポートを実行すると、値が 0 でないときに、数量は 0 です。この問題は、次の製品で発生します。
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 サービス パック 1
解決策
修正プログラムの情報
サポートされている修正プログラムはマイクロソフトから現在入手可能です。ただし、この資料に記載されている問題を解決するためのものはのみ。この特定の問題が発生したシステムにのみ適用してください。この修正プログラムは、今後さらにテストを行うことがあります。この問題で深刻な影響を受けていない場合は、次の Microsoft Dynamics NAV 2009 サービス パックまたは修正プログラムを含む次の Microsoft Dynamics NAV バージョン待つことを勧めします。
注: かかる料金が免除されるテクニカル サポート担当者 Microsoft Dynamics および関連製品のことは、通常は特別な場合は、特定の更新プログラムは、問題を解決するにを決定します。追加の質問および問題の特定のアップデートの対象にはなりませんが、通常のサポート料金が適用されます。
インストール情報
マイクロソフトでは解説することのみを目的としてプログラミング例を提供しています。暗示あるいは明示していることに対しての保証はしておりません。ここで言う保証とは、特定の目的に対する商品性や適合性の暗示的保証を含んでいますが、それに限定されるわけではありません。この資料では、例示されているプログラミング言語およびプロシージャの作成やデバッグに使用するツールにお客様が精通していることを前提としています。マイクロソフトのサポート エンジニアは、特定のプロシージャの機能について説明することができます。ただし、お客様固有の要件を満たすために、追加機能の提供またはプロシージャの作成のために、これらの例に変更を加えたりはしません。
注: この修正プログラムをインストールする前に、Microsoft Navision のすべてのクライアント ユーザーがシステムの電源を記録することを確認します。これには、Microsoft Navision アプリケーション サービス (NAS) クライアントのユーザーが含まれます。この修正プログラムを実装すると、ログオンしている唯一のクライアント ユーザーが必要です。
この修正プログラムを実装するには、開発者用のライセンスが必要です。
ユーザー アカウントまたはデータベース ログイン ウィンドウに Windows のログイン ウィンドウにある「スーパー」ロール id を割り当てられていることをお勧めします。ユーザー アカウントには、「スーパー」ロール ID を割り当てることができません、する場合は、ユーザー アカウントが次のアクセス許可を持っているを確認する必要があります。
-
変更するオブジェクトの変更のアクセス許可。
-
システム オブジェクトの ID 5210オブジェクトおよびシステム オブジェクトの ID 9015オブジェクトの実行が許可されます。
注:
データの修復を実行する必要があるない限り、データ ストアへの権限を持っている必要はありません。
コードの変更
注: 常にテスト コードを修正、管理された環境で適用する前に、運用コンピューターに修正プログラムします。
この問題を解決するには、次の手順を実行します。
-
項目 Jnl のSetValuationDateAllValueEntrie関数に新しいFixedApplicationのブール値パラメーターを追加する-次のように Post 行 codeunit (22)。
PROCEDURE SetValuationDateAllValueEntrie@95(ItemLedgerEntryNo@1000 : Integer;ValuationDate@1001 : Date;FixedApplication@1003 : Boolean);
-
項目 Jnl のSetValuationDateAllValueEntrie関数内のコードを変更する-次のように Post 行 codeunit (22)。
既存のコード... IF FINDSET THEN
REPEAT
IF ("Valuation Date" <> "Posting Date") OR
// Delete the following line.
("Valuation Date" < ValuationDate)
THEN BEGIN
"Valuation Date" := ValuationDate;
MODIFY;
END;
UNTIL NEXT = 0;
...置換用コード
... IF FINDSET THEN
REPEAT
IF ("Valuation Date" <> "Posting Date") OR
// Add the following lines.
("Valuation Date" < ValuationDate) OR // Add an OR in this condition.
(("Valuation Date" > ValuationDate) AND FixedApplication) // Add a new condition.
// End of the lines.
THEN BEGIN
"Valuation Date" := ValuationDate;
MODIFY;
END;
UNTIL NEXT = 0;
... -
項目 Jnl の(反映しない)関数のコードを変更する-次のように Post 行 codeunit (22)。
既存のコード...// Delete the following line.
SetValuationDateAllValueEntrie(CostItemLedgEntry."Entry No.",Valuationdate);
...置換用コード
...// Add the following line.
SetValuationDateAllValueEntrie(CostItemLedgEntry."Entry No.",Valuationdate,FALSE);
... -
項目 Jnl のCostApply関数内のコードを変更する-次のように Post 行 codeunit (22)。
既存のコード...// Delete the following line.
SetValuationDateAllValueEntrie(GlobalItemLedgEntry."Entry No.",ValueEntry."Valuation Date");
...置換用コード
...// Add the following line.
SetValuationDateAllValueEntrie(GlobalItemLedgEntry."Entry No.",ValueEntry."Valuation Date",FALSE);
... -
項目 Jnl のGetValuationDate関数内のコードを変更する-次のように Post 行 codeunit (22)。
既存のコード... IF Positive THEN BEGIN
IF (ValueEntry."Posting Date" < OldValueEntry."Valuation Date") OR
(ItemJnlLine."Applies-to Entry" <> 0)
// Delete the following lines.
THEN BEGIN
ValueEntry."Valuation Date" := OldValueEntry."Valuation Date";
SetValuationDateAllValueEntrie(ValueEntry."Item Ledger Entry No.",OldValueEntry."Valuation Date");
END ELSE
BEGIN
ValueEntry."Valuation Date" := ValueEntry."Posting Date";
SetValuationDateAllValueEntrie(ValueEntry."Item Ledger Entry No.",ValueEntry."Posting Date");
END
// End of the lines.
...置換用コード
... IF Positive THEN BEGIN
IF (ValueEntry."Posting Date" < OldValueEntry."Valuation Date") OR
(ItemJnlLine."Applies-to Entry" <> 0)
// Add the following lines.
THEN BEGIN
ValueEntry."Valuation Date" := OldValueEntry."Valuation Date";
SetValuationDateAllValueEntrie(
ValueEntry."Item Ledger Entry No.",
OldValueEntry."Valuation Date",
ItemJnlLine."Applies-to Entry" <> 0)
END ELSE BEGIN
ValueEntry."Valuation Date" := ValueEntry."Posting Date";
SetValuationDateAllValueEntrie(
ValueEntry."Item Ledger Entry No.",
ValueEntry."Posting Date",
ItemJnlLine."Applies-to Entry" <> 0)
END
// End of the lines.
...
必要条件
この修正プログラムを適用するのにはインストールされている製品は次のいずれかが必要です。
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 サービス パック 1
アンインストール情報
この修正プログラムを削除することはできません。
状況
マイクロソフトは、この問題を「対象製品」セクションに記載されているマイクロソフト製品の問題として認識しています。
注: これは、マイクロソフト サポートの組織内から直接作成した「高速公開」の資料です。ここに含まれる情報は、新たに発生している問題に応じて現状のまま提供されています。速やかに利用できるようにした結果として、内容には誤植が含まれている可能性があり、事前告知なしで改訂する場合があります。その他の考慮事項については、使用条件を参照してください。