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

الأعراض

عند إنشاء فاتورة دفعة مقدمة في Microsoft Dynamics NAV 2009، تتلقى رسالة الخطأ التالية:

رقم الدفعة المقدمة " السلسلة يجب أن تكون لدى قيمة "رأس" البيع/الشراء. "

يحدث هذا فقط إذا كان لديك لا إعداد سلسلة أرقام فواتير الدفع المسبق. اتبع الخطوات الموجودة في المقطع تغييرات التعليمات البرمجية لحل هذه المشكلة. تحدث هذه المشكلة في المنتجات التالية:

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 SP1

الحل

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

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

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

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

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

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

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

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

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

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

    الكائن.

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

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

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

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

  1. تغيير التعليمات البرمجية في الحقول في "الجدول رأس المبيعات" (36) كما يلي:
    التعليمات البرمجية الموجودة 1

    ... IF "Prepayment No. Series" <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(SalesSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series");
    // End of the deleted line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

    استبدال رمز 1

    ...IF "Prepayment No. Series" <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series");
    // End of the added line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

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

    ...SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    IF NoSeriesMgt.LookupSeries(SalesSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series") THEN
    // End of the deleted line.

    VALIDATE("Prepayment No. Series");
    Rec := SalesHeader;
    END;
    ...

    استبدال رمز 2

    ...
    SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series") THEN
    // End of the added line.

    VALIDATE("Prepayment No. Series");
    Rec := SalesHeader;
    END;
    ...

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

    ... IF "Prepmt. Cr. Memo No." <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(SalesSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No.");
    // End of the deleted line.

    END;
    TESTFIELD("Prepmt. Cr. Memo No.",'');
    END;
    ...

    استبدال رمز 3

    ... IF "Prepmt. Cr. Memo No." <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series");
    // End of the added line.

    END;
    TESTFIELD("Prepmt. Cr. Memo No.",'');
    END;
    ...

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

    ...SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following lines.
    IF NoSeriesMgt.LookupSeries(GetPostingNoSeriesCode,"Prepmt. Cr. Memo No.") THEN
    VALIDATE("Prepmt. Cr. Memo No.");
    // End of the deleted lines.

    Rec := SalesHeader;
    END;
    END;
    ...

    استبدال رمز 4

    ...SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following lines.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series") THEN
    VALIDATE("Prepmt. Cr. Memo No. Series");
    // End of the added lines.

    Rec := SalesHeader;
    END;
    END;
    ...
  2. تغيير التعليمات البرمجية في وظيفة جيتبوستينجبريبايمينتنوسيريسكو في "المبيعات رأس الجدول" (36) كما يلي:
    التعليمات البرمجية الموجودة

    ...EXIT(SalesSetup."Posted Invoice Nos.");
    END;

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...

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

    ... EXIT(SalesSetup."Posted Invoice Nos.");
    END;

    // Add the following lines.
    LOCAL PROCEDURE GetPostingPrepaymentNoSeriesCo@59() : Code[10];
    BEGIN
    IF "Document Type" IN ["Document Type"::"Return Order","Document Type"::"Credit Memo"] THEN
    EXIT(SalesSetup."Posted Prepmt. Cr. Memo Nos.");
    EXIT(SalesSetup."Posted Prepmt. Inv. Nos.");
    END;
    // End of the added lines.

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...
  3. تغيير التعليمات البرمجية في الحقول في "جدول رأس الشراء" (38) كما يلي:
    التعليمات البرمجية الموجودة 1

    ...IF "Prepayment No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(PurchSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series");
    // End of the deleted line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

    استبدال رمز 1

    ...IF "Prepayment No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series");
    // End of the added line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

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

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    IF NoSeriesMgt.LookupSeries(PurchSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series") THEN
    // End of the deleted line.

    VALIDATE("Prepayment No. Series");
    Rec := PurchHeader;
    END;
    ...

    استبدال رمز 2

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series") THEN
    // End of the added line.

    VALIDATE("Prepayment No. Series");
    Rec := PurchHeader;
    END;
    ...

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

    ...IF "Prepmt. Cr. Memo No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(PurchSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No. Series");
    // End of the deleted line.

    END;

    // Delete the following line.
    TESTFIELD("Prepmt. Cr. Memo No. Series",'');
    // End of the deleted line.

    END;

    OnLookup=BEGIN
    ...

    استبدال رمز 3

    ...IF "Prepmt. Cr. Memo No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series");
    // End of the added line.

    END;

    // Add the following line.
    TESTFIELD("Prepmt. Cr. Memo No.",'');
    // End of the added line.

    END;

    OnLookup=BEGIN
    ...

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

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following line.
    IF NoSeriesMgt.LookupSeries(PurchSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No. Series") THEN
    // End of the deleted line.

    VALIDATE("Prepmt. Cr. Memo No. Series");
    Rec := PurchHeader;
    END;
    ...

    استبدال رمز 4

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following line.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series") THEN
    // End of the added line.

    VALIDATE("Prepmt. Cr. Memo No. Series");
    Rec := PurchHeader;
    END;
    ...
  4. تغيير التعليمات البرمجية في وظيفة جيتبوستينجبريبايمينتنوسيريسكو في "جدول رأس الشراء" (38) كما يلي:
    التعليمات البرمجية الموجودة

    ...EXIT(PurchSetup."Posted Invoice Nos.");
    END;

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...

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

    ...EXIT(PurchSetup."Posted Invoice Nos.");
    END;

    // Add the following lines.
    LOCAL PROCEDURE GetPostingPrepaymentNoSeriesCo@37() : Code[10];
    BEGIN
    IF "Document Type" IN ["Document Type"::"Return Order","Document Type"::"Credit Memo"] THEN
    EXIT(PurchSetup."Posted Prepmt. Cr. Memo Nos.");
    EXIT(PurchSetup."Posted Prepmt. Inv. Nos.");
    END;
    // End of the added lines.

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...

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

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

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 SP1

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

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

الحالة

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

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

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

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

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

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

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

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

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

×