تنطبق هذه المقالة على Microsoft Dynamics NAV 2009 لجميع البلدان وجميع اللغات المحلية.
الأعراض
عندما تقوم بإدخال بند فاتورة لحساب دفتر الأستاذ العام المحدد كفاتورة الحساب في مجموعة ترحيل في Microsoft Dynamics NAV 2009 العميل التقريبي، يحسب مبلغ ضريبة القيمة المضافة (VAT) بشكل غير صحيح. مبلغ ضريبة القيمة المضافة لفاتورة الحساب في دفتر الأستاذ العام الإدخال التقريبي يجب أن تكون صفراً.
تحدث هذه المشكلة في المنتجات التالية:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
-
Microsoft Dynamics NAV 2009
الحل
معلومات الإصلاح العاجل
الآن يتوفر إصلاح عاجل معتمد من Microsoft. ومع ذلك، هو فقط لتصحيح المشكلة الموضحة في هذه المقالة. تطبيقها فقط على الأنظمة التي تواجه هذه المشكلة بالتحديد. قد يتم إجراء اختبارات إضافية على هذا الإصلاح العاجل. ولذلك، إذا لم يكن تأثير المشكلة كبيرا، نوصي بالانتظار حتى الإصدار التالي من حزمة الخدمة Microsoft Dynamics NAV 2009 أو الإصدار Microsoft Dynamics التنقل التالي الذي يحتوي على هذا الإصلاح العاجل.
ملاحظة: في بعض الحالات، يحدد المصروفات التي تحتسب عادة لدعم قد يتم إلغاء المكالمات إذا "أخصائي الدعم التقني" ل Microsoft Dynamics والمنتجات ذات الصلة أن تحديثًا معيناً سوف يعمل على حل المشكلة. سيتم اضافة تكاليف الدعم المعتادة على أسئلة الدعم الإضافية والمشاكل التي لا يأهل على حلها للتحديث المطلوب.
معلومات التثبيت
تقدم Microsoft أمثلة برمجية للتوضيح فقط، دون أي ضمان صريح أو ضمني. هذا يتضمن، على سبيل المثال لا الحصر، الضمانات الضمنية الخاصة بالتسويق أو الملاءمة لغرض معين. تفترض هذه المقالة أنك معتاد على لغة البرمجة التي يتم شرحها والأدوات المستخدمة لإنشاء الإجراءات وتصحيحها. يساعد مهندسو الدعم لدى Microsoft في شرح وظيفة إجراء محدد، لكنهم لن يقوموا بتعديل هذه الأمثلة لتقديم وظيفة إضافية أو إنشاء إجراءات تستوفي متطلبات محددة.
ملاحظة: قبل تثبيت هذا الإصلاح العاجل، تأكد من تسجيل خروج النظام كافة المستخدمين عميل Microsoft Navision. ويشمل ذلك المستخدمين عميل Microsoft خدمات التطبيق Navision (NAS). يجب أن يكون عميل فقط المستخدم الذي تم تسجيل دخوله عند تطبيق هذا الإصلاح العاجل.
لتطبيق هذا الإصلاح العاجل، يجب أن يكون لديك ترخيص مطور.
نوصي بأن تعيين حساب المستخدم في إطار عمليات تسجيل دخول Windows أو في إطار "قاعدة بيانات تسجيل الدخول" بمعرف دور "رئيسي". إذا كان حساب المستخدم لا يمكن تعيين معرف دور "سوبر"، يجب التحقق من أن حساب المستخدم يملك الأذونات التالية:
-
إذن "تعديل" للكائن الذي سيتم تغيير.
-
إذن Execute للكائن 5210 معرف كائن النظام والكائن 9015 معرف كائن النظام .
ملاحظة: ليس لديك حق لمخازن البيانات ما لم يكن لديك لإجراء إصلاح البيانات.
تغييرات التعليمات البرمجية
ملاحظة: دوماً التعليمات البرمجية للاختبار إصلاح في بيئة تسيطر عليها قبل تطبيق إصلاحات لأجهزة الكمبيوتر الإنتاج.
لحل هذه المشكلة، اتبع الخطوات التالية.
-
إنشاء دالة جيتكبجينفرونداكك جديد يستخدم نوع الكود لقيمة الإرجاع (الطول 20) في الجدول "بند المبيعات" (37). لإنشاء هذه الوظيفة، اتبع الخطوات التالية:
-
إضافة متغير محلي جديد ثم قم بتحديد المتغير كما يلي:
-
الاسم: Cust@1012
-
نوع البيانات: سجل
-
النوع الفرعي: العميل
-
-
إضافة متغير محلي جديد ثم قم بتحديد المتغير كما يلي:
-
الاسم: CustPostingGroup@1013
-
نوع البيانات: سجل
-
النوع الفرعي: مجموعة ترحيل العميل
-
-
إضافة متغير محلي جديد ثم قم بتحديد المتغير كما يلي:
-
الاسم: CustTemplate@1014
-
نوع البيانات: سجل
-
النوع الفرعي: قالب العميل
-
-
إضافة متغير محلي جديد ثم قم بتحديد المتغير كما يلي:
-
الاسم: SalesSetup@1008
-
نوع البيانات: سجل
-
النوع الفرعي: المبيعات وإعداد الحسابات المدينة
-
-
أضف التعليمات البرمجية كما يلي:
SalesSetup.GET;IF SalesSetup."Invoice Rounding" THEN BEGIN
IF Cust.GET(SalesHeader."Bill-to Customer No.") THEN
CustPostingGroup.GET(Cust."Customer Posting Group")
ELSE
IF CustTemplate.GET(SalesHeader."Sell-to Customer Template Code") THEN
CustPostingGroup.GET(CustTemplate."Customer Posting Group");
END;
EXIT(CustPostingGroup."Invoice Rounding Account");
-
-
حذف المتغيرات المحلية التالية في الدالة كالكفاتامونتلينيس في الجدول "بند المبيعات" (37):
-
Cust@1012
-
CustPostingGroup@1013
-
CustTemplate@1014
-
-
تغيير التعليمات البرمجية في وظيفة كالكفاتامونتلينيس في الجدول "بند المبيعات" (37) كما يلي:
التعليمات البرمجية الموجودة…WITH SalesLine DO BEGIN
SETRANGE("Document Type",SalesHeader."Document Type");
SETRANGE("Document No.",SalesHeader."No.");
SalesSetup.GET;
IF SalesSetup."Invoice Rounding" THEN BEGIN
IF Cust.GET(SalesHeader."Bill-to Customer No.") THEN
CustPostingGroup.GET(Cust."Customer Posting Group")
ELSE
IF CustTemplate.GET(SalesHeader."Sell-to Customer Template Code") THEN
CustPostingGroup.GET(CustTemplate."Customer Posting Group");
END;
IF FINDSET THEN
REPEAT
IF NOT ZeroAmountLine(QtyType) THEN BEGIN
IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
RoundingLineInserted := ("No." = CustPostingGroup."Invoice Rounding Account") OR RoundingLineInserted;
IF "VAT Calculation Type" IN
["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]
…استبدال التعليمات البرمجية
…WITH SalesLine DO BEGIN
SETRANGE("Document Type",SalesHeader."Document Type");
SETRANGE("Document No.",SalesHeader."No.");
IF FINDSET THEN
REPEAT
IF NOT ZeroAmountLine(QtyType) THEN BEGIN
IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
RoundingLineInserted := ("No." = GetCPGInvRoundAcc) OR RoundingLineInserted;
IF "VAT Calculation Type" IN
["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]
… -
إنشاء دالة جيتفبجينفرونداكك جديد يستخدم نوع التعليمات البرمجية (الطول 20) لقيمة الإرجاع في الجدول "بند الشراء" (39). لإنشاء هذه الوظيفة، اتبع الخطوات التالية:
-
إضافة متغير محلي جديد ثم قم بتحديد المتغير كما يلي:
-
الاسم: Vendor@1000
-
نوع البيانات: سجل
-
النوع الفرعي: المورد
-
-
إضافة متغير محلي جديد ثم قم بتحديد المتغير كما يلي:
-
الاسم: VendorPostingGroup@1001
-
نوع البيانات: سجل
-
النوع الفرعي: مجموعة ترحيل المورد
-
-
إضافة متغير محلي جديد ثم قم بتحديد المتغير كما يلي:
-
الاسم: PurchSetup@1002
-
نوع البيانات: سجل
-
النوع الفرعي: الشراء وإعداد الحسابات الدائنة
-
-
أضف التعليمات البرمجية كما يلي:
PurchSetup.GET; IF PurchSetup."Invoice Rounding" THEN
IF Vendor.GET(PurchHeader."Pay-to Vendor No.") THEN
VendorPostingGroup.GET(Vendor."Vendor Posting Group");
EXIT(VendorPostingGroup."Invoice Rounding Account");
-
-
حذف المتغيرات المحلية التالية في الدالة كالكفاتامونتلينيس في الجدول "بند الشراء" (39):
-
Vendor@1012
-
VendorPostingGroup@1013
-
-
تغيير التعليمات البرمجية في وظيفة كالكفاتامونتلينيس في الجدول "بند الشراء" (39):
التعليمات البرمجية الموجودة…WITH PurchLine DO BEGIN
SETRANGE("Document Type",PurchHeader."Document Type");
SETRANGE("Document No.",PurchHeader."No.");
PurchSetup.GET;
IF PurchSetup."Invoice Rounding" THEN BEGIN
Vendor.GET(PurchHeader."Pay-to Vendor No.");
VendorPostingGroup.GET(Vendor."Vendor Posting Group");
END;
IF FINDSET THEN
REPEAT
IF NOT ZeroAmountLine(QtyType) THEN BEGIN
IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
RoundingLineInserted := ("No." = VendorPostingGroup."Invoice Rounding Account") OR RoundingLineInserted;
IF "VAT Calculation Type" IN
["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]
…استبدال التعليمات البرمجية
…WITH PurchLine DO BEGIN
SETRANGE("Document Type",PurchHeader."Document Type");
SETRANGE("Document No.",PurchHeader."No.");
IF FINDSET THEN
REPEAT
IF NOT ZeroAmountLine(QtyType) THEN BEGIN
IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
RoundingLineInserted := ("No." = GetVPGInvRoundAcc) OR RoundingLineInserted;
IF "VAT Calculation Type" IN
["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]
…
المتطلبات الأساسية
يجب أن يكون لديك أحد المنتجات التالية مثبتة لتطبيق هذا الإصلاح العاجل:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
-
Microsoft Dynamics NAV 2009
معلومات الإزالة
لا يمكنك إزالة هذا الإصلاح العاجل.
الحالة
أقرت Microsoft أن هذه مشكلة في منتجات Microsoft المسردة في قسم "ينطبق على".
ملاحظة: وهذا المقال "النشر السريع" التي تم إنشاؤها مباشرة من داخل مؤسسة دعم Microsoft. وتقدم المعلومات الواردة في هذه الوثيقة كاستجابه للمسائل الناشئة. نتيجة للسرعة في توفيره، قد تتضمن الأخطاء المطبعية المواد ويمكن مراجعة في أي وقت دون سابق إنذار. راجع شروط الاستخدام لاعتبارات أخرى.