تخطي إلى المحتوى الرئيسي
الدعم
تسجيل الدخول باستخدام حساب Microsoft
تسجيل الدخول أو إنشاء حساب.
مرحباً،
تحديد استخدام حساب مختلف!
لديك حسابات متعددة
اختر الحساب الذي تريد تسجيل الدخول باستخدامه.

الأعراض

عند إنشاء فاتورة تصحيحية إذا تم تغيير حقل شركة أسعار ضريبة القيمة المضافة ، قيم سعر الوحدة غير صحيحة في إصدار Microsoft Dynamics NAV 2009 R2 المجرية. اتبع الخطوات الموجودة في المقطع تغييرات التعليمات البرمجية لحل هذه المشكلة. تحدث هذه المشكلة في المنتجات التالية:

  • إصدار Microsoft Dynamics NAV 2009 R2 المجرية

الحل

معلومات الإصلاح العاجل

الآن يتوفر إصلاح عاجل معتمد من Microsoft. ومع ذلك، هو فقط لتصحيح المشكلة الموضحة في هذه المقالة. تطبيقها فقط على الأنظمة التي تواجه هذه المشكلة بالتحديد. قد يتم إجراء اختبارات إضافية على هذا الإصلاح العاجل. ولذلك، إذا لم يكن تأثير المشكلة كبيرا، نوصي بالانتظار حتى الإصدار التالي من حزمة الخدمة Microsoft Dynamics NAV 2009 أو الإصدار Microsoft Dynamics التنقل التالي الذي يحتوي على هذا الإصلاح العاجل.

ملاحظة: في بعض الحالات، يحدد المصروفات التي تحتسب عادة لدعم قد يتم إلغاء المكالمات إذا "أخصائي الدعم التقني" ل Microsoft Dynamics والمنتجات ذات الصلة أن تحديثًا معيناً سوف يعمل على حل المشكلة. سيتم اضافة تكاليف الدعم المعتادة على أسئلة الدعم الإضافية والمشاكل التي لا يأهل على حلها للتحديث المطلوب.

معلومات التثبيت

تقدم Microsoft أمثلة برمجية للتوضيح فقط، دون أي ضمان صريح أو ضمني. هذا يتضمن، على سبيل المثال لا الحصر، الضمانات الضمنية الخاصة بالتسويق أو الملاءمة لغرض معين. تفترض هذه المقالة أنك معتاد على لغة البرمجة التي يتم شرحها والأدوات المستخدمة لإنشاء الإجراءات وتصحيحها. يساعد مهندسو الدعم لدى Microsoft شرح وظيفة إجراء محدد. ومع ذلك، لن يقوموا بتعديل هذه الأمثلة لتقديم وظيفة إضافية أو إنشاء إجراءات تستوفي متطلبات محددة.

ملاحظة: قبل تثبيت هذا الإصلاح العاجل، تأكد من تسجيل خروج النظام كافة المستخدمين عميل Microsoft Dynamics التنقل. ويشمل ذلك خدمات Microsoft Dynamics NAV تطبيق الملقم (NAS). يجب أن يكون عميل فقط المستخدم الذي تم تسجيل دخوله عند تطبيق هذا الإصلاح العاجل.

لتطبيق هذا الإصلاح العاجل، يجب أن يكون لديك ترخيص مطور.

نوصي بأن تعيين حساب المستخدم في إطار عمليات تسجيل دخول Windows أو في إطار "قاعدة بيانات تسجيل الدخول" بمعرف دور "رئيسي". إذا كان حساب المستخدم لا يمكن تعيين معرف دور "سوبر"، يجب التحقق من أن حساب المستخدم يملك الأذونات التالية:

  • إذن "تعديل" للكائن الذي سيتم تغيير.

  • إذن Execute للكائن 5210 معرف كائن النظام و نظام 9015 معرف الكائن

    الكائن.

ملاحظة: ليس لديك حق لمخازن البيانات ما لم يكن لديك لإجراء إصلاح البيانات.

تغييرات التعليمات البرمجية

ملاحظة: دوماً التعليمات البرمجية للاختبار إصلاح في بيئة تسيطر عليها قبل تطبيق إصلاحات لأجهزة الكمبيوتر الإنتاج.

لحل هذه المشكلة، اتبع الخطوات التالية.

  1. تغيير التعليمات البرمجية في وظيفة أوبداتيفاتامونتس في جدول "المبيعات تصحيح خط" (14536) كما يلي:
    التعليمات البرمجية الموجودة

    ...Amount * (1 - SalesHeader."VAT Base Discount %" / 100),
    Currency."Amount Rounding Precision");
    "Amount Including VAT" :=
    ROUND(
    Amount * (1 - SalesHeader."VAT Base Discount %" / 100) * "VAT %" / 100,
    Currency."Amount Rounding Precision",Currency.VATRoundingDirection);
    END;
    "VAT Calculation Type"::"Full VAT":
    BEGIN
    ...

    استبدال التعليمات البرمجية

    ...Amount * (1 - SalesHeader."VAT Base Discount %" / 100),
    Currency."Amount Rounding Precision");
    "Amount Including VAT" :=

    // Add the following line.
    Amount +
    // End of the added line.

    ROUND(
    Amount * (1 - SalesHeader."VAT Base Discount %" / 100) * "VAT %" / 100,
    Currency."Amount Rounding Precision",Currency.VATRoundingDirection);
    END;
    "VAT Calculation Type"::"Full VAT":
    BEGIN
    ...
  2. تغيير التعليمات البرمجية في وظيفة تشيكلينيماونت في جدول "المبيعات تصحيح خط" (14536) كما يلي:
    التعليمات البرمجية الموجودة 1

    ..."Unit Price Incl. Discount" := "Unit Price" - "Unit Price" * "Line Discount %" / 100;
    END;

    // Delete the following line.
    PROCEDURE CheckLineAmount@1360000();
    // End of the deleted line.

    BEGIN
    // PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    ...

    استبدال رمز 1

    ..."Unit Price Incl. Discount" := "Unit Price" - "Unit Price" * "Line Discount %" / 100;
    END;

    // Add the following lines.
    PROCEDURE CheckLineAmount@1170219();
    VAR
    SalesinvHeader@1170001 : Record 112;
    // End of the added lines.

    BEGIN
    // PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    ...

    التعليمات البرمجية الموجودة 2

    ...// PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    SalesCorrLine.GET("Document Type","Document No.","Correction Line No.","Before/ After correction"::Before);
    GetCorrType;
    IF (SalesCorrLine."Line Amount" > "Line Amount") AND
    ("Document Type" = "Document Type"::Invoice) AND
    (SalesCorrectionType."Correction Type" = SalesCorrectionType."Correction Type"::"Quantity and Value")
    THEN
    ...

    استبدال رمز 2

    ... // PS16433.begin
    IF "Before/ After correction" = "Before/ After correction"::After THEN BEGIN
    SalesCorrLine.GET("Document Type","Document No.","Correction Line No.","Before/ After correction"::Before);

    // Add the following line.
    SalesinvHeader.GET(SalesHeader."Corr. Document No.");
    // End of the added line.

    GetCorrType;
    IF (SalesCorrLine."Line Amount" > "Line Amount") AND

    // Add the following line.
    (SalesHeader."Prices Including VAT" = SalesinvHeader."Prices Including VAT") AND
    // End of the added line.

    ("Document Type" = "Document Type"::Invoice) AND
    (SalesCorrectionType."Correction Type" = SalesCorrectionType."Correction Type"::"Quantity and Value")
    THEN
    ...
  3. تغيير التعليمات البرمجية في بيانات البند رقم 5 في المبيعات-تقرير الفاتورة (هو) (14516) كما يلي:
    التعليمات البرمجية الموجودة

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(Before),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineBefore;
    DataItemLinkReference=Sales Invoice Header;
    DataItemLink=Document No.=FIELD(No.);
    }
    SECTIONS
    {
    ...

    استبدال التعليمات البرمجية

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(Before),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineBefore;

    // Add the following lines.
    OnAfterGetRecord=BEGIN
    IF SalesInvHeader.GET("Sales Invoice Header"."Corr. Document No.") THEN
    IF SalesInvHeader."Prices Including VAT" <> "Sales Invoice Header"."Prices Including VAT" THEN
    "Unit Price Incl. Discount" := "VAT Base Amount" / Quantity;
    END;

    // End of the added lines.

    DataItemLinkReference=Sales Invoice Header;
    DataItemLink=Document No.=FIELD(No.);
    }
    SECTIONS
    {
    ...
  4. تغيير التعليمات البرمجية في بيانات العنصر رقم 6 في المبيعات-تقرير الفاتورة (هو) (14516) كما يلي:
    التعليمات البرمجية الموجودة

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(After),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineAfter;
    DataItemLinkReference=PostedSalesCorrLineBefore;
    DataItemLink=Document No.=FIELD(Document No.),
    Correction Line No.=FIELD(Correction Line No.);
    }
    SECTIONS
    ...

    استبدال التعليمات البرمجية

    ...DataItemTable=Table14537;
    DataItemTableView=SORTING(Document No.,Correction Line No.,Before/ After correction,Document Type)
    WHERE(Before/ After correction=FILTER(After),
    Document Type=CONST(Posted Invoice));
    DataItemVarName=PostedSalesCorrLineAfter;

    // Add the following lines.
    OnAfterGetRecord=BEGIN
    IF SalesInvHeader."Prices Including VAT" <> "Sales Invoice Header"."Prices Including VAT" THEN
    "Unit Price Incl. Discount" := "VAT Base Amount" / Quantity;
    END;

    // End of the added lines.

    DataItemLinkReference=PostedSalesCorrLineBefore;
    DataItemLink=Document No.=FIELD(Document No.),
    Correction Line No.=FIELD(Correction Line No.);
    }
    SECTIONS
    ...
  5. تغيير التعليمات البرمجية في "المتغيرات العمومية" في المبيعات-تقرير الفاتورة (هو) (14516) كما يلي:
    التعليمات البرمجية الموجودة

    ...VALExchRate@1360016 : Text[50];
    Text14530@1360017 : TextConst 'ENU=%1/%2;HUN=%1/%2';
    GroupVATText@13600018 : Text[30];
    CorrInvText@1360018 : TextConst 'ENU=C O R R E C T I V E I N V O I C E;HUN=H E L Y E S B Ö T Š S Z µ M L A';
    LogInteractionEnable@19003940 : Boolean INDATASET;

    PROCEDURE InitLogInteraction@1360000();
    BEGIN
    LogInteraction := SegManagement.FindInteractTmplCode(4) <> '';
    END;
    ...

    استبدال التعليمات البرمجية

    ...VALExchRate@1360016 : Text[50];
    Text14530@1360017 : TextConst 'ENU=%1/%2;HUN=%1/%2';
    GroupVATText@13600018 : Text[30];
    CorrInvText@1360018 : TextConst 'ENU=C O R R E C T I V E I N V O I C E;HUN=H E L Y E S B Ö T Š S Z µ M L A';
    LogInteractionEnable@19003940 : Boolean INDATASET;

    // Add the following line.
    SalesInvHeader@13600019 : Record 112;
    // End of the added line.

    PROCEDURE InitLogInteraction@1360000();
    BEGIN
    LogInteraction := SegManagement.FindInteractTmplCode(4) <> '';
    END;
    ...
  6. تغيير التعليمات البرمجية في وظيفة إينيتساليسلينيونتشارجي في كوديونيت فاتكورريكتيونماناجيمينت (14535) كما يلي:
    التعليمات البرمجية الموجودة 1

    ...SalesLine.INSERT;
    CopyDim(SalesLine,SalesCorrLine);
    END;

    PROCEDURE InitSalesLineOnCharge@1360001(VAR SalesLine@1360000 : Record 37;SalesCorrLine@1360001 : Record 14536;QtyOnSalesLine@1360002 : Decimal);
    BEGIN
    InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    ...

    استبدال رمز 1

    ...SalesLine.INSERT;
    CopyDim(SalesLine,SalesCorrLine);
    END;

    PROCEDURE InitSalesLineOnCharge@1360001(VAR SalesLine@1360000 : Record 37;SalesCorrLine@1360001 : Record 14536;QtyOnSalesLine@1360002 : Decimal);

    // Add the following lines.
    VAR
    SalesInvHeader@1360003 : Record 112;
    // End of the added lines.

    BEGIN
    InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    ...

    التعليمات البرمجية الموجودة 2

    ...InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    SalesLine.VALIDATE(Quantity,QtyOnSalesLine);
    SalesLine.VALIDATE("Unit Price",SalesCorrLine."Unit Price");
    IF SalesLine.Quantity <> 0 THEN
    SalesLine.VALIDATE("Line Discount %",SalesCorrLine."Line Discount %");
    SalesLine.UpdateAmounts;
    SalesLine.VALIDATE("Unit Cost (LCY)",0);
    ...

    استبدال رمز 2

    ...InitSalesLine(SalesCorrLine,SalesLine);
    SalesLine.Type := SalesLine.Type::"Charge (Item)";
    SalesLine."No." := SalesCorrType."Item Charge Code";
    SalesLine.VALIDATE("Unit of Measure Code",'');
    SalesLine.VALIDATE(Quantity,QtyOnSalesLine);

    // Add the following lines.
    IF (SalesCorrLine."Before/ After correction" = SalesCorrLine."Before/ After correction"::Before) AND
    (SalesInvHeader.GET(SalesCorrLine."Source Document No.")) AND
    (SalesHeader."Prices Including VAT" <> SalesInvHeader."Prices Including VAT")
    THEN BEGIN
    IF SalesHeader."Prices Including VAT" THEN
    SalesLine.VALIDATE("Unit Price",SalesCorrLine."Amount Including VAT" / SalesCorrLine.Quantity)
    ELSE
    SalesLine.VALIDATE("Unit Price",SalesCorrLine."VAT Base Amount" / SalesCorrLine.Quantity);
    END ELSE
    // End of the added lines.

    SalesLine.VALIDATE("Unit Price",SalesCorrLine."Unit Price");
    IF SalesLine.Quantity <> 0 THEN
    SalesLine.VALIDATE("Line Discount %",SalesCorrLine."Line Discount %");
    SalesLine.UpdateAmounts;
    SalesLine.VALIDATE("Unit Cost (LCY)",0);
    ...


المتطلبات الأساسية

يجب أن يكون لديك أحد المنتجات التالية مثبتة لتطبيق هذا الإصلاح العاجل:

  • إصدار Microsoft Dynamics NAV 2009 R2 المجرية

معلومات الإزالة

لا يمكنك إزالة هذا الإصلاح العاجل.

الحالة

أقرت Microsoft أن هذه مشكلة في منتجات Microsoft المسردة في قسم "ينطبق على".

ملاحظة: وهذا المقال "النشر السريع" التي تم إنشاؤها مباشرة من داخل مؤسسة دعم Microsoft. وتقدم المعلومات الواردة في هذه الوثيقة كاستجابه للمسائل الناشئة. نتيجة للسرعة في توفيره، قد تتضمن الأخطاء المطبعية المواد ويمكن مراجعة في أي وقت دون سابق إنذار. راجع شروط الاستخداملاعتبارات أخرى.

هل تحتاج إلى مزيد من المساعدة؟

الخروج من الخيارات إضافية؟

استكشف مزايا الاشتراك، واستعرض الدورات التدريبية، وتعرف على كيفية تأمين جهازك، والمزيد.

تساعدك المجتمعات على طرح الأسئلة والإجابة عليها، وتقديم الملاحظات، وسماعها من الخبراء ذوي الاطلاع الواسع.

هل كانت المعلومات مفيدة؟

ما مدى رضاك عن جودة اللغة؟
ما الذي أثّر في تجربتك؟
بالضغط على "إرسال"، سيتم استخدام ملاحظاتك لتحسين منتجات Microsoft وخدماتها. سيتمكن مسؤول تكنولوجيا المعلومات لديك من جمع هذه البيانات. بيان الخصوصية.

نشكرك على ملاحظاتك!

×