이 문서의 Microsoft Dynamics 탐색 모든 국가 모든 언어 로케일에 적용 됩니다.
증상
VAT를 포함 하 여 가격이 설정 되어 있다고 가정 하 고 선불 송장 Microsoft Dynamics 탐색 2009 년에는 압축 되지 않습니다. 선불 청구서를 게시 하면 다음과 같은 오류 메시지가 나타납니다.
금액은 Gen. 업무 일지 줄에서 양수 여야 합니다.
다음 제품에이 문제가 발생합니다.
-
Microsoft Dynamics 탐색 2009 서비스 팩 1 (SP1)
-
Microsoft Dynamics 탐색 2009 R2
해결 방법
핫픽스 정보
지원 되는 핫픽스를 Microsoft에서 출시 되었습니다. 이 문서에 설명 되어 있는 문제를 해결 하기 위한 것일 뿐입니다. 이러한 특정 문제가 발생 한 시스템에만 적용 됩니다. 이 핫픽스는 추가 테스트가 필요할 수 있습니다. 따라서이 문제의 영향이 심각 하지 다음 Microsoft Dynamics 탐색 2009 서비스 팩 또는이 핫픽스가 포함 된 다음 Microsoft Dynamics 탐색 버전까지 기다리는 것이 좋습니다.
참고: 특별 한 경우 일반적으로 호출 취소 될 수도 있습니다 경우 기술 지원 담당자는 Microsoft Dynamics 및 관련 된 제품에 대 한 지원에 따른 비용이 특정 업데이트로 문제를 해결할 수 있다고 결정 합니다. 추가 지원 질문과 특정 업데이트가 필요 하지 않은 문제에는 일반 지원 비용이 적용 됩니다.
설치 정보
Microsoft는 모든 보증, 그림에 대 한 묵시적인 보증. 이 포함 되지만 상품성 또는 특정 목적에의 적합성의 묵시적된 보증에 국한 되지는 않습니다. 이 문서는 작성 하 고 프로시저를 디버깅할 데 사용 되는 도구 및 여기서 설명 하는 프로그래밍 언어에 익숙한 가정 합니다. Microsoft 지원 엔지니어는 특정 프로시저의 기능을 설명할 수 있지만 추가 기능을 제공 하거나 특정 요구 사항에 맞도록 프로시저를 구성 하는 이러한 예제를 수정 하지 않습니다.
참고: 이 핫픽스를 설치 하기 전에 모든 Microsoft Navision 클라이언트 사용자가 시스템 로그를 확인 하십시오. Navision 응용 프로그램 서비스 (NAS) 클라이언트 사용자가 포함 됩니다. 이 핫픽스를 구현할 때 로그온 되어 있는 사용자만 클라이언트 수 있습니다. 이 핫픽스를 구현 하려면 개발자 라이센스가 있어야 합니다. 것을 권장 합니다 Windows 로그인 창이 나 데이터베이스 로그인 창에서 사용자 계정 "SUPER" 역할 ID를 할당할 수 사용자 계정 "SUPER" 역할 ID를 할당할 수 없습니다, 사용자 계정에 다음 권한이 있는지 확인 해야 합니다.-
변경할 수 있는 개체에 대 한 수정 권한이 있습니다.
-
시스템 개체 ID 9015 개체 및 시스템 개체 ID 5210 개체에 대 한 Execute 권한이 있습니다.
참고: 데이터 복구를 수행 해야 할 경우가 아니면 데이터 저장소에 대 한 권한을 가질 필요가 없습니다.
코드 변경 사항
참고: 항상 테스트 코드 수정 제어 된 환경에 적용 하기 전에 프로덕션 컴퓨터에 수정 프로그램입니다.
이 문제를 해결하려면 다음과 같이 하십시오.-
판매 게시물 Codeuint (80) AdjustPrepmtAmountLCY 함수에서 코드를 다음과 같이 변경.
기존 코드 1...TotalPrepmtAmount@1002 : ARRAY [2] OF Decimal;
BEGIN ...대체 코드 1
...TotalPrepmtAmount@1002 : ARRAY [2] OF Decimal;
// Add the following line. PricesInclVATRoundingAmount@1170000000 : ARRAY [2] OF Decimal; // End of the added line. BEGIN ...기존 코드 2
...TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)";
...대체 코드 2
...
// Add the following lines.IF SalesHeader."Prices Including VAT" THEN IF (("Prepayment %" <> 100) OR IsFinalInvoice) AND (DeductionFactor = 1) THEN BEGIN PricesInclVATRoundingAmount[1] := TotalRoundingAmount[1]; PricesInclVATRoundingAmount[2] := TotalRoundingAmount[2]; END; // End of the added lines. TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)"; ...기존 코드 3
...UpdatePrepmtSalesLineWithRound(
// Delete the following line. PrepmtSalesLine,TotalRoundingAmount,TotalPrepmtAmount,TempPrepmtDeductLCYSalesLine.IsFinalInvoice); // End of the deleted line. END; ...대체 코드 3
...UpdatePrepmtSalesLineWithRound(
// Add the following lines. PrepmtSalesLine,TotalRoundingAmount,TotalPrepmtAmount, TempPrepmtDeductLCYSalesLine.IsFinalInvoice,PricesInclVATRoundingAmount); // End of the added lines. END; ... -
판매 게시물 Codeuint (80) UpdatePrepmtSalesLineWithRound 함수에서 코드를 다음과 같이 변경.
기존 코드 1...
// Delete the following line. LOCAL PROCEDURE UpdatePrepmtSalesLineWithRound@89(VAR PrepmtSalesLine@1002 : Record 37;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal;FinalInvoice@1170000000 : Boolean); // End of the deleted line. VAR ...대체 코드 1
...
// Add the following line. LOCAL PROCEDURE UpdatePrepmtSalesLineWithRound@89(VAR PrepmtSalesLine@1002 : Record 37;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal;FinalInvoice@1170000000 : Boolean;PricesInclVATRoundingAmount@1170000001 : ARRAY [2] OF Decimal); // End of the added line. VAR ...기존 코드 2
...
// Delete the following line.IF (ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision") OR FinalInvoice THEN BEGIN // End of the deleted line. IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN ...대체 코드 2
...
// Add the following lines. IF (PricesInclVATRoundingAmount[1] <> 0) AND (TotalRoundingAmount[1] = 0) THEN BEGIN Prepmt100PctVATRoundingAmt := 0; PricesInclVATRoundingAmount[1] := 0; END; IF (ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision") OR (FinalInvoice AND (TotalRoundingAmount[1] = 0)) THEN BEGIN // End of the added lines. IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN ...기존 코드 3
...END;
// Delete the following lines. "Prepmt. VAT Amount Inv. (LCY)" := TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt; NewAmountIncludingVAT := Amount + TotalPrepmtAmount[2] + TotalRoundingAmount[2]; Increment(TotalSalesLineLCY."Amount Including VAT","Amount Including VAT" - NewAmountIncludingVAT - Prepmt100PctVATRoundingAmt); // End of the deleted lines. IF "Currency Code" = '' THEN ...대체 코드 3
...END;
// Add the following lines. IF (PricesInclVATRoundingAmount[2] <> 0) AND (TotalRoundingAmount[2] = 0) THEN BEGIN Prepmt100PctVATRoundingAmt := 0; PricesInclVATRoundingAmount[2] := 0; END; "Prepmt. VAT Amount Inv. (LCY)" := TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt; NewAmountIncludingVAT := Amount + TotalPrepmtAmount[2] + TotalRoundingAmount[2]; IF (PricesInclVATRoundingAmount[1] = 0) AND (PricesInclVATRoundingAmount[2] = 0) THEN Increment(TotalSalesLineLCY."Amount Including VAT","Amount Including VAT" - NewAmountIncludingVAT - Prepmt100PctVATRoundingAmt ); // End of the added lines. IF "Currency Code" = '' THEN ... -
Purch. AdjustPrepmtAmountLCY 함수에서 코드를 변경-다음과 같이 게시물 Codeunit (90).
기존 코드 1...TotalPrepmtAmount@1003 : ARRAY [2] OF Decimal;
BEGIN ...대체 코드 1
...TotalPrepmtAmount@1003 : ARRAY [2] OF Decimal;
// Add the following line. PricesInclVATRoundingAmount@1170000000 : ARRAY [2] OF Decimal; // End of the added line. BEGIN ...기존 코드 2
...TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)";
...대체 코드 2
...
// Add the following lines. IF PurchHeader."Prices Including VAT" THEN IF (("Prepayment %" <> 100) OR IsFinalInvoice) AND (DeductionFactor = 1) THEN BEGIN PricesInclVATRoundingAmount[1] := TotalRoundingAmount[1]; PricesInclVATRoundingAmount[2] := TotalRoundingAmount[2]; END; // End of the added lines. TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)"; ...기존 코드 3
...
// Delete the following line. UpdatePrepmtPurchLineWithRound(PrepmtPurchLine,TotalRoundingAmount,TotalPrepmtAmount); // End of the deleted line. END; ...대체 코드 3
...
// Add the following lines. UpdatePrepmtPurchLineWithRound( PrepmtPurchLine,TotalRoundingAmount,TotalPrepmtAmount, TempPrepmtDeductLCYPurchLine.IsFinalInvoice,PricesInclVATRoundingAmount); // End of the added lines. END; ... -
Purch. UpdatePrepmtPurchLineWithRound 함수에서 코드를 변경-다음과 같이 게시물 Codeunit (90).
기존 코드 1...
// Delete the following line.LOCAL PROCEDURE UpdatePrepmtPurchLineWithRound@89(VAR PrepmtPurchLine@1002 : Record 39;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal); // End of the deleted line. VAR ...대체 코드 1
...
// Add the following line. LOCAL PROCEDURE UpdatePrepmtPurchLineWithRound@89(VAR PrepmtPurchLine@1002 : Record 39;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal;FinalInvoice@1170000001 : Boolean;PricesInclVATRoundingAmount@1170000000 : ARRAY [2] OF Decimal); // End of the added line. VAR ...기존 코드 2
...
// Delete the following line. IF ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision" THEN BEGIN // End of the deleted line. IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN ...대체 코드 2
...
// Add the following lines. IF (PricesInclVATRoundingAmount[1] <> 0) AND (TotalRoundingAmount[1] = 0) THEN BEGIN Prepmt100PctVATRoundingAmt := 0; PricesInclVATRoundingAmount[1] := 0; END; IF (ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision") OR (FinalInvoice AND (TotalRoundingAmount[1] = 0)) THEN BEGIN // End of the added lines. IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN ...기존 코드 3
...END;
// Delete the following lines. "Prepmt. VAT Amount Inv. (LCY)" := -(TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt); NewAmountIncludingVAT := Amount - (TotalPrepmtAmount[2] + TotalRoundingAmount[2]); Increment( TotalPurchLineLCY."Amount Including VAT",-("Amount Including VAT" - NewAmountIncludingVAT + Prepmt100PctVATRoundingAmt)); // End of the deleted lines. IF "Currency Code" = '' THEN ...대체 코드 3
...END;
// Add the following lines. IF (PricesInclVATRoundingAmount[2] <> 0) AND (TotalRoundingAmount[2] = 0) THEN BEGIN Prepmt100PctVATRoundingAmt := 0; PricesInclVATRoundingAmount[2] := 0; END; "Prepmt. VAT Amount Inv. (LCY)" := -(TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt); NewAmountIncludingVAT := Amount - (TotalPrepmtAmount[2] + TotalRoundingAmount[2]); IF (PricesInclVATRoundingAmount[1] = 0) AND (PricesInclVATRoundingAmount[2] = 0) THEN Increment( TotalPurchLineLCY."Amount Including VAT",-("Amount Including VAT" - NewAmountIncludingVAT + Prepmt100PctVATRoundingAmt)); // End of the added lnies. IF "Currency Code" = '' THEN ...
전제 조건
이 핫픽스를 적용 하려면 설치한 다음 제품 중 하나가 있어야 합니다.
-
Microsoft Dynamics 탐색 2009 서비스 팩 1 (SP1)
-
Microsoft Dynamics 탐색 2009 R2
제거 정보
이 핫픽스를 제거할 수 없습니다.
상태
Microsoft는 이 문제가 '적용 대상' 섹션에 나열된 Microsoft 제품의 문제임을 확인했습니다.
참고: 이 문서는 Microsoft 지원 부서 내에서 직접 작성한 "빠른 게시" 문서입니다. 여기에 포함된 정보는 신흥 문제에 대한 응답으로 제공되었습니다. 신속히 사용할 수 있도록 작성되었으므로, 자료 입력 오류가 포함될 수 있으며 언제든지 예고없이 개정될 수 있습니다. 다른 고려 사항은 사용 약관을 참조하십시오.