Преминаване към основното съдържание
Поддръжка
Влизане с Microsoft
Влезте или създайте акаунт.
Здравейте,
Изберете друг акаунт.
Имате няколко акаунта
Изберете акаунта, с който искате да влезете.

Когато използвате валута в Microsoft Dynamics NAV 2009, свързана сума се изчислява неправилно в приложи клиент или доставчик записи страници се прилага, ако приложите плащане във валута фактури в местната валута. Този проблем възниква в следните продукти:

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

Решение

Информация за актуалната корекция

Вече се предлага от Microsoft предоставя поддържана актуална корекция. Обаче е предназначена само за коригиране на описания в тази статия. Прилагайте корекцията само към системи, изпитващи този конкретен проблем. Възможно е провеждането на допълнителни тестове на тази актуална корекция. Следователно ако не сте силно засегнати от този проблем, препоръчваме да изчакате следващия сервизен пакет за Microsoft Dynamics NAV 2009 или следващата версия на Microsoft Dynamics NAV, който ще съдържа тази корекция.

Забележка: При специални случаи таксите, които са за свързани с поддръжката обаждания могат да бъдат отменени, ако специалист по техническа поддръжка за Microsoft Dynamics и свързани с тях продукти определя, че конкретна актуализация може да разреши проблема. Обичайните такси за поддръжката ще важат за допълнителни въпроси и проблеми, които не спадат към съответната актуализация.

Информация за инсталирането

Microsoft предоставя примери само за илюстративни цели без гаранция за определени цели. Това включва, но не е ограничено до, подразбиращи се гаранции за продаваемост или годност за определена цел. Тази статия се предполага, че сте запознати с демонстрирания език за програмиране и инструментите, които се използват за създаване и процедури за отстраняване на грешки. Инженерите на поддръжката на Microsoft могат да помогнат обяснение на функциите на конкретна процедура. Въпреки това те няма да модифицират тези примери с цел осигуряване на допълнителна функционалност или създаване на процедури за удовлетворение на конкретните ви изисквания.

Забележка: Преди да инсталирате тази актуална корекция, уверете се, че всички потребители на клиента на Microsoft Dynamics NAV са излезли от системата. Това включва и услуги на Microsoft Dynamics NAV приложение сървър (NAS). Трябва да бъде само клиент потребител, който е влязъл при прилагане на тази актуална корекция.

За прилагане на тази актуална корекция, трябва да имате лиценз разработчик.

Препоръчително е потребителският акаунт в прозореца влизания в Windows или в прозореца на БД присвояването на "Супер" ИД на роля. Ако потребителският акаунт не може да бъде възложена ИД на роля на "Супер", трябва да проверите, че потребителският акаунт има следните права:

  • Разрешение за промяна на обекта, ще се променя.

  • Разрешението за изпълнение за системата обект номер 5210 обект и системата обект ID 9015

    обект.

Забележка: Не трябва да имате права на съхранените данни, освен ако трябва да извършите възстановяване на данни.

Промени код

Забележка винаги тест код корекции в управлявана среда, преди да приложите корекциите за производство компютри. Преди да приложите промяната, импортирайте всички SEPA актуализации.

За да разрешите този проблем, изпълнете следните стъпки:

  1. Промяна на код в свойствата на свързване (232) както следва:
    Съществуващ код

    ...OnModifyRecord=BEGIN
    CODEUNIT.RUN(CODEUNIT::"Cust. Entry-Edit",Rec);
    EXIT(FALSE);
    END;
    ...

    Замени код

    ...OnModifyRecord=BEGIN
    CODEUNIT.RUN(CODEUNIT::"Cust. Entry-Edit",Rec);
    IF "Applies-to ID" <> xRec."Applies-to ID" THEN
    CalcApplnAmount;
    EXIT(FALSE);
    END;
    ...
  2. Променяте функцията HandlChosenEntries във формуляра за свързване (232) както следва:
    Съществуващ код 1

    ...IF NOT FromZeroGenJnl THEN
    AppliedCustLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
    IF AppliedCustLedgEntryTemp.FINDFIRST THEN BEGIN
    AppliedCustLedgEntryTemp.CALCFIELDS("Remaining Amount");

    IF Type = Type::Direct THEN
    CalculateCurrency := ApplyingCustLedgEntry."Entry No." <> 0
    ELSE
    CalculateCurrency := TRUE;


    IF (CurrencyCode <> AppliedCustLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
    AppliedCustLedgEntryTemp."Remaining Amount" :=
    GenJnlPostLine.ExchAmount(
    AppliedCustLedgEntryTemp."Remaining Amount",
    AppliedCustLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
    GenJnlPostLine.ExchAmount(
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible",
    AppliedCustLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedCustLedgEntryTemp."Amount to Apply" :=
    GenJnlPostLine.ExchAmount(
    AppliedCustLedgEntryTemp."Amount to Apply",
    AppliedCustLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    END;

    CASE Type OF
    Type::Direct:
    ...

    Замени код 1

    ...IF NOT FromZeroGenJnl THEN
    AppliedCustLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
    IF AppliedCustLedgEntryTemp.FINDFIRST THEN BEGIN
    ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedCustLedgEntryTemp);

    CASE Type OF
    Type::Direct:
    ...

    Съществуващ код 2

    ...END ELSE BEGIN
    AppliedCustLedgEntryTemp.SETRANGE(Positive);
    AppliedCustLedgEntryTemp.FINDFIRST;
    END;

    IF (OldPmtDisc <> PmtDiscAmount) THEN
    ...

    Замени код 2

    ...END ELSE BEGIN
    AppliedCustLedgEntryTemp.SETRANGE(Positive);
    AppliedCustLedgEntryTemp.FINDFIRST;
    ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedCustLedgEntryTemp);
    END;

    IF (OldPmtDisc <> PmtDiscAmount) THEN
    ...
  3. Променяте функцията ExchangeAmountsOnLedgerEntry във формуляра за свързване (232) както следва:
    Съществуващ код

    ...CheckRounding;
    END;

    BEGIN
    END.
    }
    ...

    Замени код

    ...CheckRounding;
    END;

    LOCAL PROCEDURE ExchangeAmountsOnLedgerEntry@20(Type@1003 : 'Direct,GenJnlLine,SalesHeader';CurrencyCode@1000 : Code[10];VAR AppliedCustLedgEntryTemp@1001 : Record 21);
    VAR
    CalculateCurrency@1002 : Boolean;
    BEGIN
    AppliedCustLedgEntryTemp.CALCFIELDS("Remaining Amount");

    IF Type = Type::Direct THEN
    CalculateCurrency := ApplyingCustLedgEntry."Entry No." <> 0
    ELSE
    CalculateCurrency := TRUE;

    IF (CurrencyCode <> AppliedCustLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
    AppliedCustLedgEntryTemp."Remaining Amount" :=
    GenJnlPostLine.ExchAmount(
    AppliedCustLedgEntryTemp."Remaining Amount",
    AppliedCustLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
    GenJnlPostLine.ExchAmount(
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible",
    AppliedCustLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedCustLedgEntryTemp."Amount to Apply" :=
    GenJnlPostLine.ExchAmount(
    AppliedCustLedgEntryTemp."Amount to Apply",
    AppliedCustLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    END;
    END;

    BEGIN
    END.
    }
    ...
  4. Промяна на код в свойствата на записи за доставчици (233) както следва:
    Съществуващ код

    ...OnModifyRecord=BEGIN
    CODEUNIT.RUN(CODEUNIT::"Vend. Entry-Edit",Rec);
    EXIT(FALSE);
    END;
    ...

    Замени код

    ...OnModifyRecord=BEGIN
    CODEUNIT.RUN(CODEUNIT::"Vend. Entry-Edit",Rec);
    IF "Applies-to ID" <> xRec."Applies-to ID" THEN
    CalcApplnAmount;
    EXIT(FALSE);
    END;
    ...
  5. Променяте функцията HandlChosenEntries във формуляра за записи за доставчици (233) както следва:
    Съществуващ код 1

    ...IF NOT FromZeroGenJnl THEN
    AppliedVendLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
    IF AppliedVendLedgEntryTemp.FINDFIRST THEN BEGIN
    AppliedVendLedgEntryTemp.CALCFIELDS("Remaining Amount");

    IF Type = Type::Direct THEN
    CalculateCurrency := ApplyingVendLedgEntry."Entry No." <> 0
    ELSE
    CalculateCurrency := TRUE;


    IF (CurrencyCode <> AppliedVendLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
    AppliedVendLedgEntryTemp."Remaining Amount" :=
    GenJnlPostLine.ExchAmount(
    AppliedVendLedgEntryTemp."Remaining Amount",
    AppliedVendLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
    GenJnlPostLine.ExchAmount(
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible",
    AppliedVendLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedVendLedgEntryTemp."Amount to Apply" :=
    GenJnlPostLine.ExchAmount(
    AppliedVendLedgEntryTemp."Amount to Apply",
    AppliedVendLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    END;

    CASE Type OF
    Type::Direct:
    ...

    Замени код 1

    ...IF NOT FromZeroGenJnl THEN
    AppliedVendLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0);
    IF AppliedVendLedgEntryTemp.FINDFIRST THEN BEGIN
    ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedVendLedgEntryTemp);

    CASE Type OF
    Type::Direct:
    ...

    Съществуващ код 2

    ...END ELSE BEGIN
    AppliedVendLedgEntryTemp.SETRANGE(Positive);
    AppliedVendLedgEntryTemp.FINDFIRST;
    END;

    IF (OldPmtdisc <> PmtDiscAmount) THEN
    ...

    Замени код 2

    ...END ELSE BEGIN
    AppliedVendLedgEntryTemp.SETRANGE(Positive);
    AppliedVendLedgEntryTemp.FINDFIRST;
    ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedVendLedgEntryTemp);
    END;

    IF (OldPmtdisc <> PmtDiscAmount) THEN
    ...
  6. Променяте функцията ExchangeAmountsOnLedgerEntry във формуляра за записи за доставчици (233) както следва:
    Съществуващ код

    ...AppliesToID := AppliesToID2;
    END;

    BEGIN
    END.
    }
    ...

    Замени код

    ...AppliesToID := AppliesToID2;
    END;

    PROCEDURE ExchangeAmountsOnLedgerEntry@14(Type@1000 : 'Direct,GenJnlLine,PurchHeader';CurrencyCode@1001 : Code[10];VAR AppliedVendLedgEntryTemp@1002 : Record 25);
    VAR
    CalculateCurrency@1003 : Boolean;
    BEGIN
    AppliedVendLedgEntryTemp.CALCFIELDS("Remaining Amount");

    IF Type = Type::Direct THEN
    CalculateCurrency := ApplyingVendLedgEntry."Entry No." <> 0
    ELSE
    CalculateCurrency := TRUE;

    IF (CurrencyCode <> AppliedVendLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN
    AppliedVendLedgEntryTemp."Remaining Amount" :=
    GenJnlPostLine.ExchAmount(
    AppliedVendLedgEntryTemp."Remaining Amount",
    AppliedVendLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" :=
    GenJnlPostLine.ExchAmount(
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible",
    AppliedVendLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    AppliedVendLedgEntryTemp."Amount to Apply" :=
    GenJnlPostLine.ExchAmount(
    AppliedVendLedgEntryTemp."Amount to Apply",
    AppliedVendLedgEntryTemp."Currency Code",
    CurrencyCode,"Posting Date");
    END;
    END;

    BEGIN
    END.
    }
    ...


Необходими условия:

Трябва да имате един от следните продукти, за да приложите тази спешна корекция:

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 SP1

Информация за премахване

Не можете да премахнете тази актуална корекция.

Статус

Microsoft потвърждава, че това е проблем в продуктите на Microsoft, изброени в раздела "Отнася се за".

Забележка: Това е статия "Бърза публикация", създадени директно от организацията за поддръжка на Microsoft. Информацията тук се предоставя "както-е" в отговор на появили се проблеми. В резултат на скоростта на предоставянето му материалите могат да съдържат печатни грешки и могат да бъдат коригирани по всяко време без предизвестие. Вижте Условияза други съображения.

Нуждаете ли се от още помощ?

Искате ли още опции?

Разгледайте ползите от абонамента, прегледайте курсовете за обучение, научете как да защитите устройството си и още.

Общностите ви помагат да задавате и отговаряте на въпроси, да давате обратна връзка и да получавате информация от експерти с богати знания.

Беше ли полезна тази информация?

Доколко сте доволни от качеството на езика?
Какво е повлияло на вашия потребителски опит?
Като натиснете „Подаване“, вашата обратна връзка ще се използва за подобряване на продуктите и услугите на Microsoft. Вашият ИТ администратор ще може да събира тези данни. Декларация за поверителност.

Благодарим ви за обратната връзка!

×