Platí pro
Dynamics NAV 2009

Tento článek se týká aplikace Microsoft Dynamics NAV ve všech zemích a všechna národní prostředí jazyka.

Příznaky

Při vytvoření smlouvy o poskytování služeb (Nepředplacená) a změna faktury před zaúčtováním v produktu Microsoft Dynamics NAV 2009, je nekonzistentní data mezi položky servisu a financí. K tomuto problému dochází v následujících produktů:

  • Aplikace Microsoft Dynamics NAV 2009 R2

  • Aplikace Microsoft Dynamics NAV 2009 Service Pack 1

Řešení

Informace o opravě hotfix

Podporovaná oprava hotfix je nyní k dispozici od společnosti Microsoft. Však je určena pouze k odstranění problému popsaného v tomto článku. Použijte ji pouze u systémů, ve kterých dochází k tomuto konkrétnímu problému. Tato oprava hotfix může být dále testována. Proto pokud jste závažně tento problém, doporučujeme počkat na další aktualizaci service pack produktu Microsoft Dynamics NAV 2009 nebo další verze produktu Microsoft Dynamics NAV, která obsahuje tuto opravu hotfix.Poznámka: Ve zvláštních případech poplatky, které jsou třeba obvykle zaplatit za telefonní hovory mohou být stornovány, jestliže pracovník technické podpory společnosti Microsoft Dynamics a souvisejících produktů Určuje, že konkrétní aktualizace odstraní váš problém. Výdaje na technickou podporu použije dalších otázek a problémů, které nelze vyřešit konkrétní aktualizací.

Informace o instalaci

Společnost Microsoft poskytuje ukázky programování pouze pro ilustraci bez žádné záruky výslovně uvedené nebo odvozené. To zahrnuje, ale není omezen pouze na předpokládané záruky obchodovatelnosti nebo vhodnosti pro určitý účel. Tento článek předpokládá, že jste obeznámeni s programovacím jazykem, který je předmětem ukázky a s nástroji, které slouží k vytvoření a ladění skriptu. Pracovníci podpory společnosti Microsoft mohou vysvětlit funkce určitého postupu. Nemohou však následující příklady rozšířit o další funkce nebo konstrukce podle konkrétních požadavků.Poznámka: Před instalací této opravy hotfix ověřte, že všichni uživatelé klienta Microsoft Navision odhlášeni systému. To zahrnuje uživatele klienta Microsoft Navision Application Services (NAS). Je třeba klienta pouze uživatel přihlášený při implementaci opravy hotfix.Chcete-li implementovat tuto opravu hotfix, musí mít licenci vývojáře.Doporučujeme, aby uživatelský účet v okně přihlášení systému Windows nebo v okně přihlášení databáze přidělí "SUPER" ID role. Pokud uživatelský účet nelze přiřadit ID role "SUPER", musíte ověřit, že uživatelský účet má následující oprávnění:

  • Změnit oprávnění pro objekt, který budete měnit.

  • Oprávnění ke spuštění pro System Object ID 5210 objekt a System Object ID 9015 objekt.

Poznámka: Nemáte práva k úložištím dat. Pokud nebudete provádět opravu dat.

Změny kódu

Poznámka: Vždy otestujte opravy kódu v kontrolovaném prostředí před instalací opravy v provozních počítačích.Chcete-li vyřešit tento problém, postupujte takto:

  1. Změňte kód v tabulce dimenze dokladu (357) takto:Existující kód 1

    ...      Text005@1009 : TextConst 'ENU=Canceled.';      Text006@1010 : TextConst 'ENU=You may have changed a dimension. Some lines are already shipped. When you post the line with the changed dimension to the general ledger, amounts on the Inventory Interim account will be out of balance when reported per dimension.\\Do you want to update the lines?';    PROCEDURE UpdateGlobalDimCode@25(GlobalDimCodeNo@1000 : Integer;"Table ID"@1001 : Integer;"Document Type"@1002 : Option;"Document No."@1003 : Code[20];"Line No."@1004 : Integer;NewDimValue@1005 : Code[20]);...

    Změněný kód 1

    ...      Text005@1009 : TextConst 'ENU=Canceled.';      Text006@1010 : TextConst 'ENU=You may have changed a dimension. Some lines are already shipped. When you post the line with the changed dimension to the general ledger, amounts on the Inventory Interim account will be out of balance when reported per dimension.\\Do you want to update the lines?';      Text007@1011 : TextConst 'ENU=You cannot change the dimension because the document is based on a service contract.';    PROCEDURE UpdateGlobalDimCode@25(GlobalDimCodeNo@1000 : Integer;"Table ID"@1001 : Integer;"Document Type"@1002 : Option;"Document No."@1003 : Code[20];"Line No."@1004 : Integer;NewDimValue@1005 : Code[20]);...

    Existující kód 2

    ...    PROCEDURE VerifyLineDim@5(VAR DocDim@1000 : Record 357);    VAR      SalesLine@1001 : Record 37;      PurchaseLine@1002 : Record 39;    BEGIN      CASE "Table ID" OF        DATABASE::"Sales Line":          BEGIN            IF SalesLine.GET(DocDim."Document Type",DocDim."Document No.",DocDim."Line No.") THEN              IF (SalesLine."Qty. Shipped Not Invoiced" <> 0) OR (SalesLine."Return Rcd. Not Invd." <> 0) THEN                IF NOT CONFIRM(Text004,TRUE,SalesLine.TABLECAPTION) THEN                  ERROR(Text005)          END;        DATABASE::"Purchase Line":          BEGIN            IF PurchaseLine.GET(DocDim."Document Type",DocDim."Document No.",DocDim."Line No.") THEN              IF (PurchaseLine."Qty. Rcd. Not Invoiced" <> 0) OR (PurchaseLine."Return Qty. Shipped Not Invd." <> 0) THEN                IF NOT CONFIRM(Text004,TRUE,PurchaseLine.TABLECAPTION) THEN                  ERROR(Text005)          END;      END;    END;...

    Náhradní kód 2

    ...    PROCEDURE VerifyLineDim@5(VAR DocDim@1000 : Record 357);    VAR      SalesLine@1001 : Record 37;      PurchaseLine@1002 : Record 39;      ServiceHeader@1003 : Record 5900;      ServiceLine@1004 : Record 5902;    BEGIN      CASE "Table ID" OF        DATABASE::"Sales Line":          BEGIN            IF SalesLine.GET(DocDim."Document Type",DocDim."Document No.",DocDim."Line No.") THEN              IF (SalesLine."Qty. Shipped Not Invoiced" <> 0) OR (SalesLine."Return Rcd. Not Invd." <> 0) THEN                IF NOT CONFIRM(Text004,TRUE,SalesLine.TABLECAPTION) THEN                  ERROR(Text005)          END;        DATABASE::"Purchase Line":          BEGIN            IF PurchaseLine.GET(DocDim."Document Type",DocDim."Document No.",DocDim."Line No.") THEN              IF (PurchaseLine."Qty. Rcd. Not Invoiced" <> 0) OR (PurchaseLine."Return Qty. Shipped Not Invd." <> 0) THEN                IF NOT CONFIRM(Text004,TRUE,PurchaseLine.TABLECAPTION) THEN                  ERROR(Text005)          END;        DATABASE::"Service Header":          IF ServiceHeader.GET(DocDim."Document Type",DocDim."Document No.") AND (ServiceHeader."Contract No." <> '') THEN            ERROR(Text007);        DATABASE::"Service Line":          IF ServiceLine.GET(DocDim."Document Type",DocDim."Document No.",DocDim."Line No.") THEN            IF (ServiceLine."Contract No." <> '') THEN              ERROR(Text007);      END;    END;...
  2. Změňte kód v tabulce Řádek servisu (5902) takto:Existující kód 1

    ...               IF (Quantity <> 0) AND ItemExists(xRec."No.") AND                  (("Spare Part Action" = "Spare Part Action"::"Component Replaced") OR                   ("Spare Part Action" = "Spare Part Action"::"Component Installed") OR                   ("Spare Part Action" = "Spare Part Action"::" "))               THEN                 ReserveServLine.VerifyChange(Rec,xRec);             END;    OnDelete=VAR...

    Změněný kód 1

    ...               IF (Quantity <> 0) AND ItemExists(xRec."No.") AND                  (("Spare Part Action" = "Spare Part Action"::"Component Replaced") OR                   ("Spare Part Action" = "Spare Part Action"::"Component Installed") OR                   ("Spare Part Action" = "Spare Part Action"::" "))               THEN                 ReserveServLine.VerifyChange(Rec,xRec);               IF "Document Type" = ServiceLine."Document Type"::Invoice THEN                 IF ("Appl.-to Service Entry" <> 0) AND ("Contract No." <> '') THEN                   ERROR(Text046);             END;    OnDelete=VAR...

    Existující kód 2

    ...    { 5   ;   ;Type                ;Option        ;OnValidate=BEGIN                                                                GetServHeader;                                                                TESTFIELD("Qty. Shipped Not Invoiced",0);...

    Náhradní kód 2

    ...    { 5   ;   ;Type                ;Option        ;OnValidate=BEGIN                                                                IF ("Appl.-to Service Entry" <> 0) AND ("Contract No." <> '') THEN                                                                  ERROR(Text046);                                                                GetServHeader;...

    Existující kód 3

    ...    { 6   ;   ;No.                 ;Code20        ;TableRelation=IF (Type=CONST(" ")) "Standard Text"                                                                 ELSE IF (Type=CONST(G/L Account)) "G/L Account"                                                                 ELSE IF (Type=CONST(Item)) Item                                                                 ELSE IF (Type=CONST(Resource)) Resource                                                                 ELSE IF (Type=CONST(Cost)) "Service Cost";                                                   OnValidate=VAR                                                                ShowLocMessage@1000 : Boolean;                                                              BEGIN                                                                TESTFIELD("Qty. Shipped Not Invoiced",0);...

    Změněný kód 3

    ...    { 6   ;   ;No.                 ;Code20        ;TableRelation=IF (Type=CONST(" ")) "Standard Text"                                                                 ELSE IF (Type=CONST(G/L Account)) "G/L Account"                                                                 ELSE IF (Type=CONST(Item)) Item                                                                 ELSE IF (Type=CONST(Resource)) Resource                                                                 ELSE IF (Type=CONST(Cost)) "Service Cost";                                                   OnValidate=VAR                                                                ShowLocMessage@1000 : Boolean;                                                              BEGIN                                                                IF ("Appl.-to Service Entry" <> 0) AND ("Contract No." <> '') THEN                                                                  ERROR(Text046);                                                                TESTFIELD("Qty. Shipped Not Invoiced",0);...

    Existující kód 4

    ...    { 22  ;   ;Unit Price          ;Decimal       ;OnValidate=BEGIN                                                                GetServHeader;                                                                IF ("Unit Price" > ServHeader."Max. Labor Unit Price") AND...

    Náhradní kód 4

    ...    { 22  ;   ;Unit Price          ;Decimal       ;OnValidate=BEGIN                                                                GetServHeader;                                                                IF ("Appl.-to Service Entry" > 0) AND (CurrFieldNo <> 0) THEN                                                                  ERROR(Text046,FIELDCAPTION("Unit Price"));                                                                IF ("Unit Price" > ServHeader."Max. Labor Unit Price") AND...

    Existující kód 5

    ...      Text043@1097 : TextConst 'ENU=You cannot change the value of the %1 field manually if %2 for this line is %3';      Text044@1012 : TextConst 'ENU=Do you want to split the resource line and use it to create resource lines\for the other service items with divided amounts?';      Text045@1099 : TextConst 'ENU=You cannot delete this service line because one or more service entries exist for this line.';...

    Změněný kód 5

    ...      Text043@1097 : TextConst 'ENU=You cannot change the value of the %1 field manually if %2 for this line is %3';      Text044@1012 : TextConst 'ENU=Do you want to split the resource line and use it to create resource lines\for the other service items with divided amounts?';      Text045@1099 : TextConst 'ENU=You cannot delete this service line because one or more service entries exist for this line.';     Text046@1100 : TextConst 'ENU=You cannot modify the document because it is based on a service contract.';...

Předpoklady

Musí mít jednu z následujících produktů nainstalovali tuto opravu hotfix:

  • Aplikace Microsoft Dynamics NAV 2009 R2

  • Aplikace Microsoft Dynamics NAV 2009 Service Pack 1

Informace o odinstalaci

Tato oprava hotfix nelze odebrat.

Stav

Společnost Microsoft potvrdila, že se jedná o problém v produktech společnosti Microsoft, které jsou uvedeny v části "Platí pro".

Poznámka: Toto je článek "Rychlé publikování" vytvářen přímo v rámci odborné pomoci společnosti Microsoft. Informace obsažené v tomto dokumentu jsou poskytovány tak, jak je v reakci na vznikající problémy. V důsledku rychlosti v jeho zpřístupnění materiály, mohou obsahovat typografické chyby a mohou být upraveny kdykoli bez předchozího upozornění. Viz Podmínky použití pro další aspekty.

Potřebujete další pomoc?

Chcete další možnosti?

Prozkoumejte výhody předplatného, projděte si školicí kurzy, zjistěte, jak zabezpečit své zařízení a mnohem více.