Trường "Vụ Amt Excl. VAT" được tính không chính xác sau khi bạn thay đổi giá trị "Thanh toán %" trong đơn đặt hàng ngay cả khi bạn áp dụng hotfix 2558516 trong Microsoft Dynamics NAV 2009


Bài viết này áp dụng cho Microsoft Dynamics NAV cho tất cả các nước và tất cả ngôn ngữ.

Triệu chứng


Xem xét kịch bản sau đây trong Microsoft Dynamics NAV 2009:
  • Bạn áp dụng hotfix 2558516.
    Để biết thêm thông tin, hãy bấm vào số bài viết sau để xem bài viết trong Cơ sở Kiến thức Microsoft:
    2558516 trường "Vụ Amt Excl. VAT" được tính không chính xác sau khi thay đổi giá trị "Vụ %" lệnh trong Microsoft Dynamics NAV 2009
  • Bạn gửi hóa đơn thanh toán cho đơn đặt hàng có trả % trường được chỉ định.
  • Bạn một phần tàu và một số đơn vị bộ hoá đơn.
  • Bạn mở bộ.
  • Bạn thay đổi giá trị trả % theo thứ tự.
Trong trường hợp này, trường Vụ Amt Excl. VAT được tính không đúng.
Vấn đề này xảy ra trong các sản phẩm sau:
  • Microsoft Dynamics NAV 2009 R2
  • Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

Giải pháp


Thông tin về cập nhật nóng

Microsoft hiện đã cung cấp bản cập nhật nóng được hỗ trợ. Tuy nhiên, nó chỉ được dùng để khắc phục sự cố được mô tả trong bài viết này. Áp dụng cho các hệ thống đang gặp sự cố cụ thể này. Hotfix này có thể được kiểm tra thêm. Do đó, nếu bạn không bị ảnh hưởng bởi vấn đề này, chúng tôi khuyến nghị bạn đợi cho gói dịch vụ tiếp theo của Microsoft Dynamics NAV hoặc phiên bản Microsoft Dynamics NAV tiếp theo có chứa hotfix này.

Lưu ý Trong trường hợp đặc biệt, chi phí thường phát sinh để hỗ trợ cuộc gọi có thể bị hủy bỏ nếu chuyên viên hỗ trợ kỹ thuật cho Microsoft Dynamics và sản phẩm liên quan xác định rằng một Cập Nhật cụ thể sẽ giải quyết vấn đề của bạn. Chi phí hỗ trợ thông thường sẽ áp dụng cho các vấn đề không phù hợp với bản Cập Nhật cụ thể trong câu hỏi và câu hỏi hỗ trợ bổ sung.


Thông tin cài đặt

Microsoft sẽ cung cấp chương trình mẫu để minh hoạ, không bảo hành hoặc rõ ràng hay ngụ ý. Điều này bao gồm, nhưng không giới hạn bảo đảm cho một mục đích cụ thể hoặc sự. Bài viết này giả định rằng bạn đã quen với ngôn ngữ lập trình đang được giải thích và các công cụ được sử dụng để tạo và quy trình gỡ lỗi. Các kỹ sư hỗ trợ Microsoft có thể giúp giải thích các chức năng của một quy trình cụ thể, nhưng chúng sẽ không sửa đổi những mô hình để cung cấp thêm chức năng hoặc xây dựng quy trình nhằm đáp ứng yêu cầu cụ thể của bạn.

Lưu ý Trước khi cài đặt hotfix này, xác minh rằng tất cả Microsoft Navision khách người dùng đăng xuất hệ thống. Điều này bao gồm Microsoft Navision ứng dụng dịch vụ (NAS) khách người dùng. Bạn nên khách hàng chỉ người được đăng nhập khi bạn áp dụng hotfix này.

Để áp dụng hotfix này, bạn phải có giấy phép nhà phát triển.

Chúng tôi khuyên bạn nên tài khoản người dùng trong cửa sổ thông tin đăng nhập Windows hoặc trong cửa sổ thông tin đăng nhập cơ sở dữ liệu được gán vai trò "Siêu" của bạn. Nếu tài khoản người dùng không thể gán vai trò "SUPER" ID, bạn phải xác minh rằng tài khoản người dùng có các quyền sau đây:
  • Thay đổi quyền cho các đối tượng mà bạn sẽ thay đổi.
  • Quyền thực thi các đối tượng hệ thống đối tượng ID 5210 và các đối tượng hệ thống đối tượng ID 9015 .


Lưu ý Bạn không cần phải có quyền để lưu trữ dữ liệu nếu bạn phải tiến hành sửa chữa dữ liệu.

Thay đổi mã

Lưu ý Luôn kiểm tra mã khắc phục trong một môi trường được kiểm soát trước khi bạn áp dụng bản vá để sản xuất máy tính của bạn.
Để khắc phục sự cố này, hãy làm theo các bước sau:
  1. Thay đổi mã trong hàm UpdateAmounts trong bảng bán dòng (37) như sau:
    Mã hiện tại
    ...FIELDERROR("Unit Price",STRSUBSTNO(Text047,FIELDCAPTION("Prepayment %")));
    END;
    IF SalesHeader."Document Type" <> SalesHeader."Document Type"::Invoice THEN BEGIN
    "Prepayment VAT Difference" := 0;

    // Delete the following lines.
    IF "Quantity Invoiced" = 0 THEN BEGIN
    "Prepmt. Line Amount" := ROUND("Line Amount" * "Prepayment %" / 100,Currency."Amount Rounding Precision");
    IF "Prepmt. Line Amount" < "Prepmt. Amt. Inv." THEN
    FIELDERROR("Prepmt. Line Amount",STRSUBSTNO(Text049,"Prepmt. Amt. Inv."));
    END ELSE BEGIN
    IF "Prepayment %" <> 0 THEN
    "Prepmt. Line Amount" := "Prepmt. Amt. Inv." +
    ROUND("Line Amount" * (Quantity - "Quantity Invoiced") / Quantity * "Prepayment %" / 100,
    Currency."Amount Rounding Precision")
    ELSE
    "Prepmt. Line Amount" := ROUND("Line Amount" * "Prepayment %" / 100,Currency."Amount Rounding Precision");
    IF "Prepmt. Line Amount" > "Line Amount" THEN
    FIELDERROR("Prepmt. Line Amount",STRSUBSTNO(Text049,"Prepmt. Line Amount"));
    END;
    // End of the lines.

    END;
    InitOutstandingAmount;
    IF (CurrFieldNo <> 0) AND
    NOT ((Type = Type::Item) AND (CurrFieldNo = FIELDNO("No.")) AND (Quantity <> 0) AND
    ...
    Thay thế mã
    ...FIELDERROR("Unit Price",STRSUBSTNO(Text047,FIELDCAPTION("Prepayment %")));
    END;
    IF SalesHeader."Document Type" <> SalesHeader."Document Type"::Invoice THEN BEGIN
    "Prepayment VAT Difference" := 0;

    // Add the following lines.
    "Prepmt. Line Amount" := ROUND("Line Amount" * "Prepayment %" / 100,Currency."Amount Rounding Precision");
    IF "Prepmt. Line Amount" < "Prepmt. Amt. Inv." THEN
    FIELDERROR("Prepmt. Line Amount",STRSUBSTNO(Text049,"Prepmt. Amt. Inv."));
    // End of the lines.

    END;
    InitOutstandingAmount;
    IF (CurrFieldNo <> 0) AND
    NOT ((Type = Type::Item) AND (CurrFieldNo = FIELDNO("No.")) AND (Quantity <> 0) AND
    ...
  2. Thay đổi mã trong hàm UpdateAmounts bảng mua dòng (39) như sau:
    Mã hiện tại
    ...FIELDERROR("Direct Unit Cost",STRSUBSTNO(Text043,FIELDCAPTION("Prepayment %")));
    END;
    IF PurchHeader."Document Type" <> PurchHeader."Document Type"::Invoice THEN BEGIN
    "Prepayment VAT Difference" := 0;

    // Delete the following lines.
    IF "Quantity Invoiced" = 0 THEN BEGIN
    "Prepmt. Line Amount" := ROUND("Line Amount" * "Prepayment %" / 100,Currency."Amount Rounding Precision");
    IF "Prepmt. Line Amount" < "Prepmt. Amt. Inv." THEN
    FIELDERROR("Prepmt. Line Amount",STRSUBSTNO(Text037,"Prepmt. Amt. Inv."));
    END ELSE BEGIN
    IF "Prepayment %" <> 0 THEN
    "Prepmt. Line Amount" := "Prepmt. Amt. Inv." +
    ROUND("Line Amount" * (Quantity - "Quantity Invoiced") / Quantity * "Prepayment %" / 100,
    Currency."Amount Rounding Precision")
    ELSE
    "Prepmt. Line Amount" := ROUND("Line Amount" * "Prepayment %" / 100,Currency."Amount Rounding Precision");
    IF "Prepmt. Line Amount" > "Line Amount" THEN
    FIELDERROR("Prepmt. Line Amount",STRSUBSTNO(Text037,"Prepmt. Line Amount"));
    END;
    // End of the lines.

    END;
    IF PurchHeader.Status = PurchHeader.Status::Released THEN
    UpdateVATAmounts;
    ...
    Thay thế mã
    ...FIELDERROR("Direct Unit Cost",STRSUBSTNO(Text043,FIELDCAPTION("Prepayment %")));
    END;
    IF PurchHeader."Document Type" <> PurchHeader."Document Type"::Invoice THEN BEGIN
    "Prepayment VAT Difference" := 0;

    // Add the following lines.
    "Prepmt. Line Amount" := ROUND("Line Amount" * "Prepayment %" / 100,Currency."Amount Rounding Precision");
    IF "Prepmt. Line Amount" < "Prepmt. Amt. Inv." THEN
    FIELDERROR("Prepmt. Line Amount",STRSUBSTNO(Text037,"Prepmt. Amt. Inv."));
    // End of the lines.

    END;
    IF PurchHeader.Status = PurchHeader.Status::Released THEN
    UpdateVATAmounts;
    ...
  3. Thay đổi mã trong hàm codeunit bán hàng bài trả trước (442) như sau:
    Mã hiện tại
    ...REPEAT
    IF SalesLine."Prepmt. Line Amount" <> SalesLine."Prepmt. Amt. Inv." THEN BEGIN
    SalesLine."Prepmt. Amt. Inv." := SalesLine."Prepmt. Line Amount";
    SalesLine."Prepmt. Amount Inv. Incl. VAT" := SalesLine."Prepmt. Amt. Incl. VAT";

    // Delete the following line.
    SalesLine.CalcPrepaymentToDeduct;

    SalesLine."Prepmt VAT Diff. to Deduct" :=
    SalesLine."Prepmt VAT Diff. to Deduct" + SalesLine."Prepayment VAT Difference";
    SalesLine."Prepayment VAT Difference" := 0;
    SalesLine.MODIFY;
    ...
    Thay thế mã
    ...REPEAT
    IF SalesLine."Prepmt. Line Amount" <> SalesLine."Prepmt. Amt. Inv." THEN BEGIN
    SalesLine."Prepmt. Amt. Inv." := SalesLine."Prepmt. Line Amount";
    SalesLine."Prepmt. Amount Inv. Incl. VAT" := SalesLine."Prepmt. Amt. Incl. VAT";

    // Add the following line.
    SalesLine."Prepmt Amt to Deduct" := SalesLine."Prepmt. Amt. Inv." - SalesLine."Prepmt Amt Deducted";

    SalesLine."Prepmt VAT Diff. to Deduct" :=
    SalesLine."Prepmt VAT Diff. to Deduct" + SalesLine."Prepayment VAT Difference";
    SalesLine."Prepayment VAT Difference" := 0;
    SalesLine.MODIFY;
    ...
  4. Thay đổi mã trong hàm trả trước mua bài codeunit (444) như sau:
    Mã hiện tại
    ...REPEAT
    IF PurchLine."Prepmt. Line Amount" <> PurchLine."Prepmt. Amt. Inv." THEN BEGIN
    PurchLine."Prepmt. Amt. Inv." := PurchLine."Prepmt. Line Amount";
    PurchLine."Prepmt. Amount Inv. Incl. VAT" := PurchLine."Prepmt. Amt. Incl. VAT";

    // Delete the following line.
    PurchLine.CalcPrepaymentToDeduct;

    PurchLine."Prepmt VAT Diff. to Deduct" :=
    PurchLine."Prepmt VAT Diff. to Deduct" + PurchLine."Prepayment VAT Difference";
    PurchLine."Prepayment VAT Difference" := 0;
    PurchLine.MODIFY;
    ...
    Thay thế mã
    ...REPEAT
    IF PurchLine."Prepmt. Line Amount" <> PurchLine."Prepmt. Amt. Inv." THEN BEGIN
    PurchLine."Prepmt. Amt. Inv." := PurchLine."Prepmt. Line Amount";
    PurchLine."Prepmt. Amount Inv. Incl. VAT" := PurchLine."Prepmt. Amt. Incl. VAT";

    // Add the following line.
    PurchLine."Prepmt Amt to Deduct" := PurchLine."Prepmt. Amt. Inv." - PurchLine."Prepmt Amt Deducted";

    PurchLine."Prepmt VAT Diff. to Deduct" :=
    PurchLine."Prepmt VAT Diff. to Deduct" + PurchLine."Prepayment VAT Difference";
    PurchLine."Prepayment VAT Difference" := 0;
    PurchLine.MODIFY;
    ...

Điều kiện tiên quyết

Bạn phải có một trong các sản phẩm được cài đặt để áp dụng hotfix này:
  • Microsoft Dynamics NAV 2009 R2
  • Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

Thông tin về việc loại bỏ

Bạn không thể xoá hotfix này.

Trạng thái


Microsoft đã xác nhận rằng đây là sự cố trong sản phẩm của Microsoft được liệt kê trong phần "Áp dụng cho".
Lưu ý Đây là một bài viết "XUẤT BẢN NHANH" được tạo trực tiếp từ trung tâm hỗ trợ của Microsoft. Thông tin này được cung cấp-trả lời cho các vấn đề mới xuất hiện. Vì nhanh chóng có sẵn, các tài liệu có thể bao gồm lỗi và có thể được sửa đổi bất kỳ lúc nào mà không cần thông báo. Xem Điều khoản sử dụng để xem xét khác.