Pierakstīties, izmantojot Microsoft
Pierakstīties vai izveidot kontu
Sveicināti!
Atlasīt citu kontu.
Jums ir vairāki konti
Izvēlieties kontu, ar kuru vēlaties pierakstīties.

Šis raksts neattiecas uz Microsoft Dynamics NAV visās valstīs un visu valodu lokalizācijas.

Pazīmes

Pieņemsim, ka ir iestatīts cenas ieskaitot PVN un priekšapmaksas rēķinu nesaspiež Microsoft Dynamics NAV 2009. gadā. Kad publicējat priekšapmaksas rēķins, tiek parādīts šāds kļūdas ziņojums:

Summa jābūt pozitīvam Gen žurnāla rindā.

Šī problēma rodas ar šādiem produktiem:

  • Microsoft Dynamics NAV 2009. gada 1. servisa pakotne (SP1)

  • Microsoft Dynamics NAV 2009 R2

Risinājums

Informācija par labojumfailu

Pašlaik korporācija Microsoft piedāvā atbalstītu labojumfailu. Tomēr tas ir paredzēts tikai šajā rakstā aprakstītās problēmas novēršanai. Izmantojiet to tikai tām sistēmām, kurām ir radusies tieši šī problēma. Iespējams, tiks veikta šī labojumfaila papildu testēšana. Tādēļ, ja jums ir šī problēma nerada nopietnus traucējumus, ieteicams nogaidīt, līdz tiks izlaista nākamā servisa pakotne Microsoft Dynamics NAV 2009 vai nākamo Microsoft Dynamics NAV versiju, kurā ir iekļauts šis labojumfails.

Piezīme. Īpašos gadījumos standarta izmaksas par atbalsta zvaniem nav jāsedz, ja tehniskā atbalsta speciālists Microsoft Dynamics un saistītiem produktiem nosaka, ka šo problēmu novērsīs noteikts atjauninājums. Parasti atbalsta izmaksas tiek piemērotas jautājumiem par papildu atbalstu un problēmām, kas neskar specifisko atjauninājumu apspriešanu.



Informācija par instalēšanu

Microsoft piedāvā programmēšanas piemērus tikai uzskatāmībai, nesniedzot nekādas tiešas vai netiešas garantijas. Tas ietver, bet neaprobežojas ar netiešām garantijām par piemērotību pārdošanai vai atbilstību noteiktam mērķim. Šajā rakstā tiek pieņemts, ka pārzināt programmēšanas valodu, kas tiek aprakstīta, un rīkus, kas tiek izmantoti, lai izveidotu un atkļūdotu procedūras. Microsoft atbalsta inženieri var palīdzēt izskaidrot kādas noteiktas procedūras funkcionalitāti, taču viņi nemainīs šos piemērus, lai sniegtu skaidrāku funkcionalitāti, un neveidos jaunas procedūras, kas atbilstu īpašām prasībām.

Piezīme. Pirms šī labojumfaila instalēšanas pārliecinieties, vai ka visi Microsoft Navision klients lietotāji ir atteikušies sistēmu. Tas ietver Microsoft Navision lietojumprogrammu pakalpojumu (NAS) klients lietotājiem. Jums ir jābūt tikai klienta lietotājam, kurš ir pieteicies datorā, kad izmantojat šo labojumfailu.

Lai ieviestu šo labojumfailu, datorā jābūt instalētai izstrādātāja licenci.

Ieteicams, ka lietotāja konts tiek atvērts logs Windows lietotājvārdi vai logā datu bāzes lietotājvārdi piešķirt "SUPER" lomas ID. Ja lietotāja kontam nevar piešķirt "SUPER" lomas ID, ir jāpārbauda lietotāja konts ir šādas atļaujas:

  • Objektu, kad tiks mainīts modificēt atļaujas.

  • Izpildes atļaujas sistēmas objekta ID 5210 objektu un sistēmas objekta ID 9015 objektu.


Piezīme. Jums nav tiesības datu krātuvju vien veikt datu labošana.

Koda izmaiņas

Piezīme. Vienmēr pārbaudes kods novērš kontrolētā vidē pirms lietojat datoru ražošanas labojumus.
Lai novērstu šo problēmu, rīkojieties šādi:

  1. Nomainiet šo kodu pārdošanas ziņu Codeuint (80) AdjustPrepmtAmountLCY funkciju šādi:
    Kods 1

    ...TotalPrepmtAmount@1002 : ARRAY [2] OF Decimal;
    BEGIN
    ...

    Aizstāšanas kods = 1

    ...TotalPrepmtAmount@1002 : ARRAY [2] OF Decimal;

    // Add the following line.
    PricesInclVATRoundingAmount@1170000000 : ARRAY [2] OF Decimal;
    // End of the added line.

    BEGIN
    ...

    Kods 2.

    ...TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)";
    ...

    Aizstāšanas kods 2.

    ...
    // Add the following lines.IF SalesHeader."Prices Including VAT" THEN
    IF (("Prepayment %" <> 100) OR IsFinalInvoice) AND (DeductionFactor = 1) THEN BEGIN
    PricesInclVATRoundingAmount[1] := TotalRoundingAmount[1];
    PricesInclVATRoundingAmount[2] := TotalRoundingAmount[2];
    END;
    // End of the added lines.

    TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)";
    ...

    Kods 3

    ...UpdatePrepmtSalesLineWithRound(

    // Delete the following line.
    PrepmtSalesLine,TotalRoundingAmount,TotalPrepmtAmount,TempPrepmtDeductLCYSalesLine.IsFinalInvoice);
    // End of the deleted line.

    END;
    ...

    Aizstāšanas kodu 3.

    ...UpdatePrepmtSalesLineWithRound(

    // Add the following lines.
    PrepmtSalesLine,TotalRoundingAmount,TotalPrepmtAmount,
    TempPrepmtDeductLCYSalesLine.IsFinalInvoice,PricesInclVATRoundingAmount);
    // End of the added lines.

    END;
    ...
  2. Nomainiet šo kodu pārdošanas ziņu Codeuint (80) UpdatePrepmtSalesLineWithRound funkciju šādi:
    Kods 1

    ...
    // Delete the following line.
    LOCAL PROCEDURE UpdatePrepmtSalesLineWithRound@89(VAR PrepmtSalesLine@1002 : Record 37;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal;FinalInvoice@1170000000 : Boolean);
    // End of the deleted line.

    VAR
    ...

    Aizstāšanas kods = 1

    ...
    // Add the following line.
    LOCAL PROCEDURE UpdatePrepmtSalesLineWithRound@89(VAR PrepmtSalesLine@1002 : Record 37;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal;FinalInvoice@1170000000 : Boolean;PricesInclVATRoundingAmount@1170000001 : ARRAY [2] OF Decimal);
    // End of the added line.

    VAR
    ...

    Kods 2.

    ...
    // Delete the following line.IF (ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision") OR FinalInvoice THEN BEGIN
    // End of the deleted line.

    IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN
    ...

    Aizstāšanas kods 2.

    ...
    // Add the following lines.
    IF (PricesInclVATRoundingAmount[1] <> 0) AND (TotalRoundingAmount[1] = 0) THEN BEGIN
    Prepmt100PctVATRoundingAmt := 0;
    PricesInclVATRoundingAmount[1] := 0;
    END;

    IF (ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision") OR
    (FinalInvoice AND (TotalRoundingAmount[1] = 0))
    THEN BEGIN
    // End of the added lines.

    IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN
    ...

    Kods 3

    ...END;

    // Delete the following lines.
    "Prepmt. VAT Amount Inv. (LCY)" := TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt;
    NewAmountIncludingVAT := Amount + TotalPrepmtAmount[2] + TotalRoundingAmount[2];
    Increment(TotalSalesLineLCY."Amount Including VAT","Amount Including VAT" - NewAmountIncludingVAT - Prepmt100PctVATRoundingAmt);
    // End of the deleted lines.

    IF "Currency Code" = '' THEN
    ...

    Aizstāšanas kodu 3.

    ...END;

    // Add the following lines.
    IF (PricesInclVATRoundingAmount[2] <> 0) AND (TotalRoundingAmount[2] = 0) THEN BEGIN
    Prepmt100PctVATRoundingAmt := 0;
    PricesInclVATRoundingAmount[2] := 0;
    END;

    "Prepmt. VAT Amount Inv. (LCY)" := TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt;
    NewAmountIncludingVAT := Amount + TotalPrepmtAmount[2] + TotalRoundingAmount[2];
    IF (PricesInclVATRoundingAmount[1] = 0) AND (PricesInclVATRoundingAmount[2] = 0) THEN
    Increment(TotalSalesLineLCY."Amount Including VAT","Amount Including VAT" - NewAmountIncludingVAT - Prepmt100PctVATRoundingAmt
    );
    // End of the added lines.

    IF "Currency Code" = '' THEN
    ...
  3. Nomainiet šo kodu funkciju AdjustPrepmtAmountLCY pirkšanas.-ziņu koda (90) šādi:
    Kods 1

    ...TotalPrepmtAmount@1003 : ARRAY [2] OF Decimal;
    BEGIN
    ...

    Aizstāšanas kods = 1

    ...TotalPrepmtAmount@1003 : ARRAY [2] OF Decimal;

    // Add the following line.
    PricesInclVATRoundingAmount@1170000000 : ARRAY [2] OF Decimal;
    // End of the added line.

    BEGIN
    ...

    Kods 2.

    ...TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)";
    ...

    Aizstāšanas kods 2.

    ...
    // Add the following lines.
    IF PurchHeader."Prices Including VAT" THEN
    IF (("Prepayment %" <> 100) OR IsFinalInvoice) AND (DeductionFactor = 1) THEN BEGIN
    PricesInclVATRoundingAmount[1] := TotalRoundingAmount[1];
    PricesInclVATRoundingAmount[2] := TotalRoundingAmount[2];
    END;
    // End of the added lines.

    TotalPrepmtAmount[1] += "Prepmt. Amount Inv. (LCY)";
    ...

    Kods 3

    ...
    // Delete the following line.
    UpdatePrepmtPurchLineWithRound(PrepmtPurchLine,TotalRoundingAmount,TotalPrepmtAmount);
    // End of the deleted line.

    END;
    ...

    Aizstāšanas kodu 3.

    ...
    // Add the following lines.
    UpdatePrepmtPurchLineWithRound(
    PrepmtPurchLine,TotalRoundingAmount,TotalPrepmtAmount,
    TempPrepmtDeductLCYPurchLine.IsFinalInvoice,PricesInclVATRoundingAmount);
    // End of the added lines.

    END;
    ...
  4. Nomainiet šo kodu funkciju UpdatePrepmtPurchLineWithRound pirkšanas.-ziņu koda (90) šādi:
    Kods 1

    ...
    // Delete the following line.LOCAL PROCEDURE UpdatePrepmtPurchLineWithRound@89(VAR PrepmtPurchLine@1002 : Record 39;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal);
    // End of the deleted line.

    VAR
    ...

    Aizstāšanas kods = 1

    ...
    // Add the following line.
    LOCAL PROCEDURE UpdatePrepmtPurchLineWithRound@89(VAR PrepmtPurchLine@1002 : Record 39;TotalRoundingAmount@1001 : ARRAY [2] OF Decimal;TotalPrepmtAmount@1000 : ARRAY [2] OF Decimal;FinalInvoice@1170000001 : Boolean;PricesInclVATRoundingAmount@1170000000 : ARRAY [2] OF Decimal);
    // End of the added line.

    VAR
    ...

    Kods 2.

    ...
    // Delete the following line.
    IF ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision" THEN BEGIN
    // End of the deleted line.

    IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN
    ...

    Aizstāšanas kods 2.

    ...
    // Add the following lines.
    IF (PricesInclVATRoundingAmount[1] <> 0) AND (TotalRoundingAmount[1] = 0) THEN BEGIN
    Prepmt100PctVATRoundingAmt := 0;
    PricesInclVATRoundingAmount[1] := 0;
    END;

    IF (ABS(TotalRoundingAmount[2]) <= GLSetup."Amount Rounding Precision") OR
    (FinalInvoice AND (TotalRoundingAmount[1] = 0))
    THEN BEGIN
    // End of the added lines.

    IF ("Prepayment %" = 100) AND ("Prepmt. Amount Inv. (LCY)" = 0) THEN
    ...

    Kods 3

    ...END;

    // Delete the following lines.
    "Prepmt. VAT Amount Inv. (LCY)" := -(TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt);
    NewAmountIncludingVAT := Amount - (TotalPrepmtAmount[2] + TotalRoundingAmount[2]);
    Increment(
    TotalPurchLineLCY."Amount Including VAT",-("Amount Including VAT" - NewAmountIncludingVAT + Prepmt100PctVATRoundingAmt));
    // End of the deleted lines.

    IF "Currency Code" = '' THEN
    ...

    Aizstāšanas kodu 3.

    ...END;

    // Add the following lines.
    IF (PricesInclVATRoundingAmount[2] <> 0) AND (TotalRoundingAmount[2] = 0) THEN BEGIN
    Prepmt100PctVATRoundingAmt := 0;
    PricesInclVATRoundingAmount[2] := 0;
    END;

    "Prepmt. VAT Amount Inv. (LCY)" := -(TotalRoundingAmount[2] + Prepmt100PctVATRoundingAmt);
    NewAmountIncludingVAT := Amount - (TotalPrepmtAmount[2] + TotalRoundingAmount[2]);
    IF (PricesInclVATRoundingAmount[1] = 0) AND (PricesInclVATRoundingAmount[2] = 0) THEN
    Increment(
    TotalPurchLineLCY."Amount Including VAT",-("Amount Including VAT" - NewAmountIncludingVAT + Prepmt100PctVATRoundingAmt));
    // End of the added lnies.

    IF "Currency Code" = '' THEN
    ...

Priekšnosacījumi

Datorā ir jābūt instalētai kādai no lai lietotu šo labojumfailu šādiem produktiem:

  • Microsoft Dynamics NAV 2009. gada 1. servisa pakotne (SP1)

  • Microsoft Dynamics NAV 2009 R2



Informācija par noņemšanu

Nevar noņemt šo labojumfailu.

Statuss

Korporācija Microsoft ir apstiprinājusi, ka šī problēma pastāv Microsoft produktos, kas ir minēti sadaļā "Attiecas uz".

Piezīme. Šis ir STEIDZAMI PUBLICĒJAMS raksts, kas izveidots tieši Microsoft atbalsta organizācijā. Šajā rakstā ietvertā informācija ir sniegta, reaģējot uz nesen konstatētām problēmām. Tā kā šis raksts ir tapis pieejams neilgā laikā, materiālos var būt pareizrakstības kļūdas un tās var tikt labotas jebkurā laikā bez paziņojuma. Skatīt Lietošanas citi apsvērumi.

Nepieciešama papildu palīdzība?

Vēlaties vairāk opciju?

Izpētiet abonementa priekšrocības, pārlūkojiet apmācības kursus, uzziniet, kā aizsargāt ierīci un veikt citas darbības.

Kopienas palīdz uzdot jautājumus un atbildēt uz tiem, sniegt atsauksmes, kā arī saņemt informāciju no ekspertiem ar bagātīgām zināšanām.

Vai šī informācija bija noderīga?

Cik lielā mērā esat apmierināts ar valodas kvalitāti?
Kas ietekmēja jūsu pieredzi?
Nospiežot Iesniegt, jūsu atsauksmes tiks izmantotas Microsoft produktu un pakalpojumu uzlabošanai. Jūsu IT administrators varēs vākt šos datus. Paziņojums par konfidencialitāti.

Paldies par jūsu atsauksmēm!

×