حساب الفائدة على المتأخرات يستخدم مبلغ غير صحيح في إصدار Microsoft Dynamics NAV 2009 الإيطالية

قالب: CPR-قالب فياككس التعليمات البرمجية Navision

الخطأ رقم: 216250 (تعديل المحتوى)

الأعراض

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

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

  • إصدار Microsoft Dynamics NAV 2009 SP1 الإيطالية

الحل

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

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

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

في حالة عدم نشر هذا الإصلاح العاجل للتنزيل العام (بمعنى عدم توفر URL عام لهذا الإصلاح العاجل في هذه المقالة)، يتطلب التوزيع التقني أو عضو فريق تصعيد أو موافقة من المدير مع مراعاة المعلومات التالية:

  • للحصول على الإصلاح العاجل، يجب أن يواجهه العملاء الخطأ المذكور في قسم "الأعراض".

  • يجب أن تعقب العملاء بإرسال هذا وتقديم حزمة الخدمة التالية لهم عندما تصبح متوفرة (في حالة أي حزمة خدمة).

هذا الإصلاح العاجل ليس من المخطط أن يتم تضمين "حزمة الخدمة ل Microsoft Dynamics التنقل".

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

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

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

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

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

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

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

    الكائن.

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

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

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

لحل هذه المشكلة، تغيير التعليمات البرمجية في "حساب الفائدة" على المتأخرات التقرير (12107) كما يلي:

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

...  IF CustLedgerEntry."Due Date" < RateInterestDate THEN BEGIN
ix +=1;
IF ix < ix2 THEN BEGIN

// Delete the following line.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + CustLedgerEntry."Amount (LCY)") *
// End of the deleted line.

CalcIntArrOr(CustLedgerEntry."Due Date", DueDateTmp[ix+1], Customer."Int. on Arrears Code")), GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

استبدال رمز 1

...IF CustLedgerEntry."Due Date" < RateInterestDate THEN BEGIN
ix +=1;
IF ix < ix2 THEN BEGIN

// Add the following lines.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + CustLedgerEntry."Closed by Amount (LCY)") *
// End of the added lines.

CalcIntArrOr(CustLedgerEntry."Due Date", DueDateTmp[ix+1], Customer."Int. on Arrears Code")), GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

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

...DD_Calculated += RateInterestDate - DueDateTmp[ix+1];
DueDate[ix] := DueDateTmp[ix+1];
END ELSE BEGIN

// Delete the following line.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + CustLedgerEntry."Amount (LCY)") *
// End of the deleted line.

CalcIntArrOr(CustLedgerEntry."Due Date", RateInterestDate, Customer."Int. on Arrears Code")),
GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

استبدال رمز 2

... DD_Calculated += RateInterestDate - DueDateTmp[ix+1];
DueDate[ix] := DueDateTmp[ix+1];
END ELSE BEGIN

// Add the following line.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + CustLedgerEntry."Closed by Amount (LCY)") *
// End of the added line.

CalcIntArrOr(CustLedgerEntry."Due Date", RateInterestDate, Customer."Int. on Arrears Code")),
GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

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

... DD_Calculated += RateInterestDate - CustLedgerEntry."Due Date";
DueDate[ix] := RateInterestDate;
END;

// Delete the following line.
TotalAmount += CustLedgerEntry."Amount (LCY)";
// End of the deleted line.

BaseAmount[ix] := TotalAmount;
RateInterestDateDetail[ix] := CustLedgerEntry."Due Date";
DocType[ix] := CustLedgerEntry."Document Type";
...

استبدال رمز 3


...DD_Calculated += RateInterestDate - CustLedgerEntry."Due Date";
DueDate[ix] := RateInterestDate;
END;

// Add the followingline.
TotalAmount += CustLedgerEntry."Closed by Amount (LCY)";
// End of the added line.

BaseAmount[ix] := TotalAmount;
RateInterestDateDetail[ix] := CustLedgerEntry."Due Date";
DocType[ix] := CustLedgerEntry."Document Type";
...

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

...IF VenLedgerEntry."Due Date" < RateInterestDate THEN BEGIN
ix +=1;
IF ix < ix2 THEN BEGIN

// Delete the following line.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + VenLedgerEntry."Amount (LCY)") *
// End of the deleted line.

CalcIntArrOr(VenLedgerEntry."Due Date", DueDateTmp[ix+1], Vendor."Int. on Arrears Code")),
GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

استبدال رمز 4

... IF VenLedgerEntry."Due Date" < RateInterestDate THEN BEGIN
ix +=1;
IF ix < ix2 THEN BEGIN

// Add the following line.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + VenLedgerEntry."Closed by Amount (LCY)") *
// End of the added line.

CalcIntArrOr(VenLedgerEntry."Due Date", DueDateTmp[ix+1], Vendor."Int. on Arrears Code")),
GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

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

...DD_Calculated += RateInterestDate - DueDateTmp[ix+1];
DueDate[ix] := DueDateTmp[ix+1];
END ELSE BEGIN

// Delete the following line.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + VenLedgerEntry."Amount (LCY)") *
// End of the deleted line.

CalcIntArrOr(VenLedgerEntry."Due Date", RateInterestDate, Vendor."Int. on Arrears Code")),
GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

استبدال رمز 5

...DD_Calculated += RateInterestDate - DueDateTmp[ix+1];
DueDate[ix] := DueDateTmp[ix+1];
END ELSE BEGIN

// Add the following line.
IntLedgerEntryDetail[ix] := ROUND(ABS((TotalAmount + VenLedgerEntry."Closed by Amount (LCY)") *
// End of the added line.

CalcIntArrOr(VenLedgerEntry."Due Date", RateInterestDate, Vendor."Int. on Arrears Code")),
GLSetup."Amount Rounding Precision");
IntLedgerEntry += IntLedgerEntryDetail[ix];
...

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

...DD_Calculated += RateInterestDate - VenLedgerEntry."Due Date";
DueDate[ix] := RateInterestDate;
END;

// Delete the following line.
TotalAmount += VenLedgerEntry."Amount (LCY)";
// End of the deleted line.

BaseAmount[ix] := TotalAmount;
RateInterestDateDetail[ix] := VenLedgerEntry."Due Date";
DocType[ix] := VenLedgerEntry."Document Type";
...

استبدال رمز 6

...DD_Calculated += RateInterestDate - VenLedgerEntry."Due Date";
DueDate[ix] := RateInterestDate;
END;

// Add the following line.
TotalAmount += VenLedgerEntry."Closed by Amount (LCY)";
// End of the added line.

BaseAmount[ix] := TotalAmount;
RateInterestDateDetail[ix] := VenLedgerEntry."Due Date";
DocType[ix] := VenLedgerEntry."Document Type";
...


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

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

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

  • إصدار Microsoft Dynamics NAV 2009 SP1 الإيطالية

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

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

الحالة

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

المراجع

ديناميكسنافسي فسفت: 361096

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

Author: alessandro.vannini
Writer: v-luzo
المراجع التقني: alessandro.vannini
Editor:

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

توسيع المهارات
استكشاف التدريب
الحصول على الميزات الجديدة أولاً
الانضمام إلى Microsoft Insider

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

ما مدى رضاك عن جودة الترجمة؟

ما الذي أثّر في تجربتك؟

هل لديك أي ملاحظات إضافية؟ (اختياري)

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

×