В тази статия се отнася за Microsoft Dynamics NAV за всички държави и всички езикови местоположения.
Симптоми
Когато създавате договор (не предплатен) и променете фактурата преди осчетоводяване в Microsoft Dynamics NAV 2009, има противоречиви данни между записи за сервиз и главна книга. Този проблем възниква в следните продукти:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1
Решение
Информация за актуалната корекция
Вече се предлага от Microsoft предоставя поддържана актуална корекция. Обаче е предназначена само за коригиране на описания в тази статия. Прилагайте корекцията само към системи, изпитващи този конкретен проблем. Възможно е провеждането на допълнителни тестове на тази актуална корекция. Следователно ако не сте силно засегнати от този проблем, препоръчваме да изчакате следващия сервизен пакет за Microsoft Dynamics NAV 2009 или следващата версия на Microsoft Dynamics NAV, който ще съдържа тази корекция.
Забележка: При специални случаи таксите, които са за свързани с поддръжката обаждания могат да бъдат отменени, ако специалист по техническа поддръжка за Microsoft Dynamics и свързани с тях продукти определя, че конкретна актуализация може да разреши проблема. Обичайните такси за поддръжката ще важат за допълнителни въпроси и проблеми, които не спадат към съответната актуализация.
Информация за инсталирането
Microsoft предоставя примери само за илюстративни цели без гаранция за определени цели. Това включва, но не е ограничено до, подразбиращи се гаранции за продаваемост или годност за определена цел. Тази статия се предполага, че сте запознати с демонстрирания език за програмиране и инструментите, които се използват за създаване и процедури за отстраняване на грешки. Инженерите на поддръжката на Microsoft могат да помогнат обяснение на функциите на конкретна процедура. Въпреки това те няма да модифицират тези примери с цел осигуряване на допълнителна функционалност или създаване на процедури за удовлетворение на конкретните ви изисквания.
Забележка: Преди да инсталирате тази актуална корекция, уверете се, че всички потребители на Microsoft Navision клиент излезли системата. Това включва Microsoft Navision Application услуги (NAS) клиент потребители. Трябва да бъде само клиент потребител, който е влязъл при прилагане на тази актуална корекция. За прилагане на тази актуална корекция, трябва да имате лиценз разработчик. Препоръчително е потребителският акаунт в прозореца влизания в Windows или в прозореца на БД присвояването на "Супер" ИД на роля. Ако потребителският акаунт не може да бъде възложена ИД на роля на "Супер", трябва да проверите, че потребителският акаунт има следните права:-
Разрешение за промяна на обекта, ще се променя.
-
Разрешението за изпълнение за системата обект номер 5210 обект и системата обект ID 9015 обект.
Забележка: Не трябва да имате права на съхранените данни, освен ако трябва да извършите възстановяване на данни.
Промени код
Забележка: Винаги тест код решава в управлявана среда преди да приложите корекциите производство компютри.
За да разрешите този проблем, изпълнете следните стъпки:-
Променете кода в таблицата аналитичност документ (357) както следва:
Съществуващ код 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]); ...Замени код 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]); ...Съществуващ код 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; ...Замени код 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; ... -
Променете кода в таблицата (5902) както следва:
Съществуващ код 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 ...Замени код 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 ...Съществуващ код 2
... { 5 ; ;Type ;Option ;OnValidate=BEGIN
GetServHeader; TESTFIELD("Qty. Shipped Not Invoiced",0); ...Замени код 2
... { 5 ; ;Type ;Option ;OnValidate=BEGIN
IF ("Appl.-to Service Entry" <> 0) AND ("Contract No." <> '') THEN ERROR(Text046); GetServHeader; ...Съществуващ код 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); ...Замени код 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); ...Съществуващ код 4
... { 22 ; ;Unit Price ;Decimal ;OnValidate=BEGIN
GetServHeader; IF ("Unit Price" > ServHeader."Max. Labor Unit Price") AND ...Замени код 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 ...Съществуващ код 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.'; ...Замени код 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.'; ...
Необходими условия:
Трябва да имате един от следните продукти, за да приложите тази спешна корекция:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1
Информация за премахване
Не можете да премахнете тази актуална корекция.
Статус
Microsoft потвърждава, че това е проблем в продуктите на Microsoft, изброени в раздела "Отнася се за".
Забележка: Това е статия "Бърза публикация", създадени директно от организацията за поддръжка на Microsoft. Информацията тук се предоставя "както-е" в отговор на появили се проблеми. В резултат на скоростта на предоставянето му материалите могат да съдържат печатни грешки и могат да бъдат коригирани по всяко време без предизвестие. Вижте Условия за други съображения.