Перейти до основного
Підтримка
Вхід
Вхід за допомогою облікового запису Microsoft
Увійдіть або створіть обліковий запис.
Вітаємо,
Виберіть інший обліковий запис.
У вас є кілька облікових записів
Виберіть обліковий запис, за допомогою якого потрібно ввійти.

Ця стаття відноситься до Microsoft Dynamics NAV області іспанська (es).

Причини

Припустімо, що змінити значення EC сума продажу або придбати рахунку статистику в іспаномовній версії Microsoft Dynamics NAV, 2009 NAV 2013. При спробі надіслати дані рахунок-фактура, змінені EC обсяг значення не зберігається.

Ця проблема виникає в таких продуктів:

  • Іспанська версії Microsoft Dynamics NAV 2009 пакетом оновлень 1

  • Іспанська версії Microsoft Dynamics NAV 2009-R2

  • Іспанська версії Microsoft Dynamics NAV, 2013


Вирішення

Відомості про виправлення

Корпорація Майкрософт випустила підтримуване виправлення доступна. Однак, застосовувати лише для вирішення проблеми, описаної в цій статті. Він придатний лише для систем, які зазнають цієї конкретної проблеми. Те, що це виправлення може потребувати додаткового тестування. Таким чином, якщо ви не завдає значної, рекомендовано почекати до виходу чергового пакета оновлень Microsoft Dynamics NAV, 2013 або наступної версії Microsoft Dynamics NAV, що містить це виправлення.

Примітка. В окремих випадках оплату звернення до служби підтримки може бути скасовано якщо технічної підтримки професійного для Microsoft Dynamics і пов'язані продукти визначає телефонів служби. Плата стягується на додаткові питання і проблеми, які не пов'язані з оновленням.

Відомості про інсталяцію

Корпорація Майкрософт надає приклади програмного коду тільки для ілюстрації, без гарантій – прямих або інших. Це включає, але не обмежується, будь-яких гарантій придатності до продажу та придатності для певної мети. У цій статті припускається, що ви знайомі з, що демонструє мову програмування та інструменти, які використовуються для створення та налагодження процедури. Співробітники служби підтримки корпорації Майкрософт можуть пояснити функціональні особливості кожної конкретної процедури. Проте вони не будуть змінювати приклади для реалізації додаткових можливостей або створювати процедури на вимогу окремих користувачів.

Примітка. Перш ніж інсталювати це виправлення, переконайтеся, що всіх користувачів Microsoft Dynamics NAV-клієнт відключився системи. Це стосується, служби Microsoft Dynamics NAV Application Server (NAS). Ви повинні тільки клієнт користувача, який увійшов до системи, під час виконання цього виправлення.

Щоб застосувати це виправлення, потрібно мати ліцензію для розробників.

Корпорація Майкрософт рекомендує, що обліковий запис користувача Windows, вхід вікна або у вікні бази даних вхід призначити "Супер" роль ID. Якщо обліковий запис користувача не призначено роль ID "Супер", необхідно переконатися, що обліковий запис користувача, має такі дозволи:

  • Змінити дозвіл об'єкт, який буде змінити.

  • Права для виконання системи об'єкт з Ідентифікатором 5210 об'єкт і, код 9015 системи-об'єкт

    об'єкт.

Примітка. Маєте відповідних прав у сховища даних, якщо не потрібно виконати дані відновлення не потрібно.

Зміни коду

Примітка. Завжди тест код вирішення в середовищі контрольовані перед інсталяцією розглянутого виправлення виробництва комп'ютерів.

Щоб вирішити цю проблему, виконайте такі дії.

  1. Змінити код у рядкуCalcVATAmountLines функції продажу рядка таблиці (37) наступним чином:
    Наявний код

    ...ROUND("Inv. Discount Amount" * QtyToHandle / Quantity,Currency."Amount Rounding Precision")
    ELSE
    VATAmountLine."Invoice Discount Amount" :=
    VATAmountLine."Invoice Discount Amount" + "Inv. Disc. Amount to Invoice";
    VATAmountLine."VAT Difference" := VATAmountLine."VAT Difference" + "VAT Difference";
    IF "Prepayment Line" THEN
    VATAmountLine."Includes Prepayment" := TRUE;
    VATAmountLine.MODIFY;
    END;
    QtyType::Shipping:
    ...

    Заміна код

    ...ROUND("Inv. Discount Amount" * QtyToHandle / Quantity,Currency."Amount Rounding Precision")
    ELSE
    VATAmountLine."Invoice Discount Amount" :=
    VATAmountLine."Invoice Discount Amount" + "Inv. Disc. Amount to Invoice";
    VATAmountLine."VAT Difference" := VATAmountLine."VAT Difference" + "VAT Difference";

    // Add the following line.
    VATAmountLine."EC Difference" := VATAmountLine."EC Difference" + "EC Difference";
    // End of the added line.

    IF "Prepayment Line" THEN
    VATAmountLine."Includes Prepayment" := TRUE;
    VATAmountLine.MODIFY;
    END;
    QtyType::Shipping:
    ...
  2. Змінити код CalcVATAmountLines функції придбання рядка таблиці (39) наступним чином:
    Наявний код

    ...ROUND("Inv. Discount Amount" * QtyToHandle / Quantity,Currency."Amount Rounding Precision")
    ELSE
    VATAmountLine."Invoice Discount Amount" :=
    VATAmountLine."Invoice Discount Amount" + "Inv. Disc. Amount to Invoice";
    VATAmountLine."VAT Difference" := VATAmountLine."VAT Difference" + "VAT Difference";
    IF "Prepayment Line" THEN
    VATAmountLine."Includes Prepayment" := TRUE;
    VATAmountLine.MODIFY;
    END;
    QtyType::Shipping:
    ...

    Заміна код

    ...ROUND("Inv. Discount Amount" * QtyToHandle / Quantity,Currency."Amount Rounding Precision")
    ELSE
    VATAmountLine."Invoice Discount Amount" :=
    VATAmountLine."Invoice Discount Amount" + "Inv. Disc. Amount to Invoice";
    VATAmountLine."VAT Difference" := VATAmountLine."VAT Difference" + "VAT Difference";

    // Add the following line.
    VATAmountLine."EC Difference" := VATAmountLine."EC Difference" + "EC Difference";
    // End of the added line.

    IF "Prepayment Line" THEN
    VATAmountLine."Includes Prepayment" := TRUE;
    VATAmountLine.MODIFY;
    END;
    QtyType::Shipping:
    ...
  3. Змінити код ПДВ розмір рядка таблиці (290), функції InsertLine наступним чином:
    Наявний код

    ..."Pmt. Disc. Given Amount" := "Pmt. Disc. Given Amount" + VATAmountLine."Pmt. Disc. Given Amount";
    "Invoice Discount Amount" := "Invoice Discount Amount" + VATAmountLine."Invoice Discount Amount";
    Quantity := Quantity + VATAmountLine.Quantity;
    "VAT+EC Base" := "VAT+EC Base" + VATAmountLine."VAT+EC Base";
    "Amount Including VAT+EC" := "Amount Including VAT+EC" + VATAmountLine."Amount Including VAT+EC";

    // Delete the following lines.
    IF ("VAT %" + "EC %" <> 0) THEN BEGIN
    "VAT Amount" := ROUND(("Amount Including VAT+EC" - "VAT+EC Base")/("VAT %" + "EC %") * "VAT %",RoundingPrec);
    "EC Amount" := ROUND(("Amount Including VAT+EC" - "VAT+EC Base")/("VAT %" + "EC %") * "EC %",RoundingPrec);
    END;
    "VAT Difference" := "VAT Difference" + VATAmountLine."VAT Difference";
    "EC Difference" := "EC Difference" + VATAmountLine."EC Difference";
    // End of the deleted lines.

    "Calculated VAT Amount" := "Calculated VAT Amount" + VATAmountLine."Calculated VAT Amount";
    "Calculated EC Amount" := "Calculated EC Amount" + VATAmountLine."Calculated EC Amount";
    MODIFY;
    END ELSE BEGIN
    IF ("VAT %" + "EC %") <> 0 THEN BEGIN
    ...

    Заміна код

    ..."Pmt. Disc. Given Amount" := "Pmt. Disc. Given Amount" + VATAmountLine."Pmt. Disc. Given Amount";
    "Invoice Discount Amount" := "Invoice Discount Amount" + VATAmountLine."Invoice Discount Amount";
    Quantity := Quantity + VATAmountLine.Quantity;
    "VAT+EC Base" := "VAT+EC Base" + VATAmountLine."VAT+EC Base";
    "Amount Including VAT+EC" := "Amount Including VAT+EC" + VATAmountLine."Amount Including VAT+EC";

    // Add the following lines.
    "VAT Difference" := "VAT Difference" + VATAmountLine."VAT Difference";
    "EC Difference" := "EC Difference" + VATAmountLine."EC Difference";
    IF ("VAT %" + "EC %" <> 0) THEN BEGIN
    "VAT Amount" := ROUND(("Amount Including VAT+EC" - "VAT+EC Base" - "VAT Difference" - "EC Difference")/
    ("VAT %" + "EC %") * "VAT %",RoundingPrec) + "VAT Difference";
    "EC Amount" := ROUND(("Amount Including VAT+EC" - "VAT+EC Base" - "VAT Difference" - "EC Difference")/
    ("VAT %" + "EC %") * "EC %",RoundingPrec) + "EC Difference";
    END;
    // End of the added lines.

    "Calculated VAT Amount" := "Calculated VAT Amount" + VATAmountLine."Calculated VAT Amount";
    "Calculated EC Amount" := "Calculated EC Amount" + VATAmountLine."Calculated EC Amount";
    MODIFY;
    END ELSE BEGIN
    IF ("VAT %" + "EC %") <> 0 THEN BEGIN
    ...


Попередні вимоги

Ви повинні мати одну з таких продуктів, щоб застосувати це виправлення:

  • Іспанська версії Microsoft Dynamics NAV 2009 пакетом оновлень 1

  • Іспанська версії Microsoft Dynamics NAV 2009-R2

  • Іспанська версії Microsoft Dynamics NAV, 2013

Відомості про видалення

Це виправлення не можна видалити.

Стан

Корпорація Майкрософт підтвердила існування цієї неполадки у продуктах Майкрософт, перелічених у розділі "Застосовується до".

Примітка. Це "Швидка публікація" статті, надана службою підтримки корпорації Майкрософт. Відомості в цій статті надано без змін у відповідь на повідомлення про проблеми. З огляду на швидкість публікації матеріали можуть містити орфографічні помилки. Їх може бути змінено в будь-який час без повідомлення. Див. Умови використанняінші міркування.

Потрібна додаткова довідка?

Потрібні додаткові параметри?

Ознайомтеся з перевагами передплати, перегляньте навчальні курси, дізнайтесь, як захистити свій пристрій тощо.

Спільноти допомагають ставити запитання й відповідати на них, надавати відгуки та дізнаватися думки висококваліфікованих експертів.

Чи ця інформація була корисною?

Наскільки ви задоволені якістю мови?
Що вплинуло на ваші враження?
Натиснувши кнопку "Надіслати", ви надасте свій відгук для покращення продуктів і служб Microsoft. Ваш ІТ-адміністратор зможе збирати ці дані. Декларація про конфіденційність.

Дякуємо за відгук!

×