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

Якщо у вас є більш складним процесом власну Польська версія Microsoft Dynamics NAV, 2009, курс валют відмінності не працює. Ця проблема виникає в таких продуктів:

  • Польська версія Microsoft Dynamics NAV 2009-R2

  • Польська версії Microsoft Dynamics NAV 2009 року з пакетом оновлень 1 (SP1)

Вирішення

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

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

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

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

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

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

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

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

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

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

    об'єкт.

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

Зміни коду

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

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

  1. Змінити код у властивостях у звіті про обчислення відмінності в Exchange (12302) наступним чином:
    Наявний код

    ...CaptionML=[ENU=Calculate Exchange Differences;
    PLK=Kalkulacja r��nic kursowych];
    ProcessingOnly=Yes;
    }
    DATAITEMS
    {
    ...

    Заміна код

    ...CaptionML=[ENU=Calculate Exchange Differences;
    PLK=Kalkulacja r��nic kursowych];
    ProcessingOnly=Yes;
    OnPreReport=BEGIN
    GLSetup.GET;
    END;

    }
    DATAITEMS
    {
    ...
  2. Змінити код у звіті про обчислення відмінності в Exchange (12302) наступним чином:
    Наявний код 1

    ...OnAfterGetRecord=VAR
    ApplBankAccountLedgerEntry@1000 : Record 271;
    AmountLCY@1001 : Decimal;
    BEGIN
    IF ((Amount < 0) OR (Amount = 0)) THEN
    CurrReport.SKIP;
    ...

    Код на заміну 1

    ...OnAfterGetRecord=VAR
    ApplBankAccountLedgerEntry@1000 : Record 271;
    AmountLCY@1001 : Decimal;
    DiffGains@1170001 : Decimal;
    DiffLosses@1170002 : Decimal;
    BEGIN
    IF ((Amount < 0) OR (Amount = 0)) THEN
    CurrReport.SKIP;
    ...

    Наявний код 2

    ...IF ((Amount < 0) OR (Amount = 0)) THEN
    CurrReport.SKIP;

    ExchRate := "Amount (LCY)" / Amount;
    RemainingAmount := Amount - "Applied Amount";
    ...

    Код на заміну 2

    ...IF ((Amount < 0) OR (Amount = 0)) THEN
    CurrReport.SKIP;

    DiffGains := 0;
    DiffLosses := 0;
    ExchRate := "Amount (LCY)" / Amount;
    RemainingAmount := Amount - "Applied Amount";
    ...

    Наявний код 3

    ...ExchDiff := -(AppAmount * ExchRate - (AmountLCY * (AppAmount / BankAccLedgEntry.Amount)));

    BankAccLedgEntry."Difference Amount" := BankAccLedgEntry."Difference Amount" + ExchDiff;
    BankAccLedgEntry."Applied Amount" := BankAccLedgEntry."Applied Amount" + AppAmount;
    BankAccLedgEntry."Remaining Amount" := BankAccLedgEntry."Remaining Amount" - AppAmount;
    ...

    Код на заміну 3

    ...ExchDiff := -(AppAmount * ExchRate - (AmountLCY * (AppAmount / BankAccLedgEntry.Amount)));

    IF ExchDiff < 0 THEN
    ExchDiff := CalcRoundedAmount(ExchDiff,DiffGains);
    IF ExchDiff > 0 THEN
    ExchDiff := CalcRoundedAmount(ExchDiff,DiffLosses);

    BankAccLedgEntry."Difference Amount" := BankAccLedgEntry."Difference Amount" + ExchDiff;
    BankAccLedgEntry."Applied Amount" := BankAccLedgEntry."Applied Amount" + AppAmount;
    BankAccLedgEntry."Remaining Amount" := BankAccLedgEntry."Remaining Amount" - AppAmount;
    ...
  3. Змінити код глобальних параметрів у звіті про обчислення відмінності в Exchange (12302) наступним чином:
    Наявний код

    ...VAR
    BankAccLedgEntry@1470000 : Record 271;
    BankAccLedgEntry2@1470003 : Record 271;
    ExchRate@1170000 : Decimal;
    ExchDiff@1170002 : Decimal;
    SumApplied@1170003 : Decimal;
    ...

    Заміна код

    ...VAR
    BankAccLedgEntry@1470000 : Record 271;
    BankAccLedgEntry2@1470003 : Record 271;
    GLSetup@1470103 : Record 98;
    ExchRate@1170000 : Decimal;
    ExchDiff@1170002 : Decimal;
    SumApplied@1170003 : Decimal;
    ...
  4. Змін у звіті про обчислення відмінності в Exchange (12302), функція CalcRoundedAmount наступним чином:
    Наявний код

    ...Recalculate := Recalculate_new;
    END;

    BEGIN
    END.
    }
    ...

    Заміна код

    ...Recalculate := Recalculate_new;
    END;

    LOCAL PROCEDURE CalcRoundedAmount@91(Amount@1000 : Decimal;VAR Remainder@1001 : Decimal) : Decimal;
    VAR
    AmountRnded@1002 : Decimal;
    BEGIN
    Amount := Amount + Remainder;
    AmountRnded := ROUND(Amount,GLSetup."Amount Rounding Precision");
    Remainder := Amount - AmountRnded;
    EXIT(AmountRnded);
    END;

    BEGIN
    END.
    }
    ...


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

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

  • Польська версія Microsoft Dynamics NAV 2009-R2

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

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

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

Стан

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

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

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

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

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

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

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

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

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

×