Denne artikkelen gjelder for Microsoft Dynamics NAV for alle land og alle språkinnstillingene.
Symptomer
Når du flytter tilbake til å redigere en nettopp opprettet bestilling i Microsoft Dynamics NAV 2009, får du følgende feilmelding:
En annen bruker har endret posten for denne bestillingshodet du hentet den fra databasen. Angi endringene på nytt i det oppdaterte vinduet.
Dette problemet oppstår i følgende produkter:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
Oppløsning
Informasjon om hurtigreparasjon
En støttet hurtigreparasjon er nå tilgjengelig fra Microsoft. Det er imidlertid bare ment å løse problemet som er beskrevet i denne artikkelen. Bruk den bare på systemer som har dette bestemte problemet. Denne hurtigreparasjonen kan gjennomgå ytterligere testing. Hvis du ikke er alvorlig påvirket av dette problemet, anbefaler vi derfor at du venter på neste oppdateringspakke for Microsoft Dynamics NAV 2009 eller den neste versjonen av Microsoft Dynamics NAV som inneholder denne hurtigreparasjonen.
Obs! I spesielle tilfeller avgifter som vanligvis påløper for støtte samtaler kan avbrytes hvis en kundestøttemedarbeider for Microsoft Dynamics og beslektede produkter avgjør at en bestemt oppdatering løser problemet. Vanlige kundestøttekostnader gjelder for ytterligere kundestøttespørsmål og problemer som ikke dekkes av den gjeldende oppdateringen.
Installasjonsinformasjon
Microsoft bruker ment som eksempler, uten garanti, verken direkte eller indirekte. Dette inkluderer, men er ikke begrenset til, eventuelle stilltiende garantier om salgbarhet eller anvendelighet for særskilte formål. Denne artikkelen forutsetter at du er kjent med programmeringsspråket som anvendes, og verktøyene som brukes til å opprette og feilsøke prosedyrer. Microsofts kundestøtteteknikere kan hjelpe deg med å forklare funksjonaliteten til en bestemt prosedyre. De endrer imidlertid ikke disse eksemplene for å lage forbedret funksjonalitet eller lage prosedyrer som dekker dine spesifikke behov.
Obs! Før du installerer denne hurtigreparasjonen, må du kontrollere at alle brukerne i Microsoft Dynamics NAV-klienten er logget av systemet. Dette inkluderer tjenester for Microsoft Dynamics NAV Application Server (NAS). Du skal bare klient-brukeren som er logget på når du implementerer denne hurtigreparasjonen.
Hvis du vil implementere denne hurtigreparasjonen, må du ha en utviklerlisens.
Vi anbefaler at kontoen i vinduet Windows-pålogging eller i vinduet Database-pålogging være tildelt "SUPER" rolle-ID. Hvis brukerkontoen ikke kan tilordnes "SUPER" rolle-IDen, må du kontrollere at brukerkontoen har følgende tillatelser:
-
Endre-tillatelse for objektet du vil endre.
-
Tilgangsnivået for systemet objekt-IDen til 5210 objektet og systemet objekt-ID-9015
-objektet.
Obs! Du har ikke tilgangsrettigheter til datalagre med mindre du har til å utføre data reparasjon.
Kodeendringer
Obs! Alltid løser teste koden i et kontrollert miljø før du installerer hurtigreparasjoner til produksjonsdatamaskiner for.
Hvis du vil løse dette problemet, bruker du følgende:
-
Endre koden i funksjonen UpdateSalesLines i tabellen Salgshode (36) som følger:
Eksisterende kode...DocDim.LOCKTABLE;
SalesLine.LOCKTABLE;
xRecRef.GETTABLE(xRec);
MODIFY;
RecRef.GETTABLE(Rec);
ChangeLogMgt.LogModification(RecRef,xRecRef);
...Ny kode
...DocDim.LOCKTABLE;
SalesLine.LOCKTABLE;
xRecRef.GETTABLE(xRec);
// Add the following lines.
IF NOT ISSERVICETIER THEN
UpdateRecord(ChangedFieldName);
// End of the added lines.
MODIFY;
RecRef.GETTABLE(Rec);
ChangeLogMgt.LogModification(RecRef,xRecRef);
... -
Endre koden i GetFieldValuefungerer i Salgshode-tabellen (36) som følger:
Eksisterende kode...NewSalesLine.VALIDATE("Bin Code",OldSalesLine."Bin Code");
IF NewSalesLine.MODIFY THEN;
END;
BEGIN
END.
}
}
...Ny kode
...NewSalesLine.VALIDATE("Bin Code",OldSalesLine."Bin Code");
IF NewSalesLine.MODIFY THEN;
END;
// Add the following lines.
LOCAL PROCEDURE GetFieldValue@91(VAR FieldRef@1000 : FieldRef;FieldName@1002 : Text[100]);
VAR
Field@1003 : Record 2000000041;
RecRef@1001 : RecordRef;
BEGIN
RecRef.GETTABLE(Rec);
Field.SETFILTER(TableNo,FORMAT(RecRef.NUMBER));
Field.SETFILTER("Field Caption",FieldName);
Field.FINDFIRST;
FieldRef := RecRef.FIELD(Field."No.");
END;
LOCAL PROCEDURE UpdateRecord@92(FieldName@1000 : Text[100]);
VAR
FieldRef@1001 : FieldRef;
BEGIN
GetFieldValue(FieldRef,FieldName);
GET("Document Type","No.");
CASE FieldName OF
FIELDCAPTION("Shipment Date"):
"Shipment Date" := FieldRef.VALUE;
FIELDCAPTION("Currency Factor"):
"Currency Factor" := FieldRef.VALUE;
FIELDCAPTION("Transaction Type"):
"Transaction Type" := FieldRef.VALUE;
FIELDCAPTION("Transport Method"):
"Transport Method" := FieldRef.VALUE;
FIELDCAPTION("Exit Point"):
"Exit Point" := FieldRef.VALUE;
FIELDCAPTION(Area):
Area := FieldRef.VALUE;
FIELDCAPTION("Transaction Specification"):
"Transaction Specification" := FieldRef.VALUE;
FIELDCAPTION("Shipping Agent Code"):
"Shipping Agent Code" := FieldRef.VALUE;
FIELDCAPTION("Shipping Agent Service Code"):
"Shipping Agent Service Code" := FieldRef.VALUE;
FIELDCAPTION("Shipping Time"):
"Shipping Time" := FieldRef.VALUE;
FIELDCAPTION("Prepayment %"):
"Prepayment %" := FieldRef.VALUE;
FIELDCAPTION("Requested Delivery Date"):
"Requested Delivery Date" := FieldRef.VALUE;
FIELDCAPTION("Promised Delivery Date"):
"Promised Delivery Date" := FieldRef.VALUE;
FIELDCAPTION("Outbound Whse. Handling Time"):
"Outbound Whse. Handling Time" := FieldRef.VALUE;
END;
END;
// End of the added lines.
BEGIN
END.
}
} -
Endre koden i funksjonen UpdatePurchLines i tabellen Bestillingshode (38) som følger:
Eksisterende kode...
DocDim.LOCKTABLE;SalesLine.LOCKTABLE;
xRecRef.GETTABLE(xRec);
MODIFY;
RecRef.GETTABLE(Rec);
ChangeLogMgt.LogModification(RecRef,xRecRef);
...Ny kode
...
DocDim.LOCKTABLE;SalesLine.LOCKTABLE;
xRecRef.GETTABLE(xRec);
// Add the following lines.
IF NOT ISSERVICETIER THEN
UpdateRecord(ChangedFieldName);
// End of the added lines.
MODIFY;
RecRef.GETTABLE(Rec);
ChangeLogMgt.LogModification(RecRef,xRecRef);
... -
Endre koden i funksjonen GetFieldValue i tabellen Bestillingshode (38) som følger:
Eksisterende kode...
NewSalesLine.VALIDATE("Bin Code",OldSalesLine."Bin Code");IF NewSalesLine.MODIFY THEN;
END;
BEGIN
END.
}
}
...Ny kode
...
NewSalesLine.VALIDATE("Bin Code",OldSalesLine."Bin Code");IF NewSalesLine.MODIFY THEN;
END;
// Add the following lines.
LOCAL PROCEDURE GetFieldValue@91(VAR FieldRef@1000 : FieldRef;FieldName@1002 : Text[100]);
VAR
Field@1003 : Record 2000000041;
RecRef@1001 : RecordRef;
BEGIN
RecRef.GETTABLE(Rec);
Field.SETFILTER(TableNo,FORMAT(RecRef.NUMBER));
Field.SETFILTER("Field Caption",FieldName);
Field.FINDFIRST;
FieldRef := RecRef.FIELD(Field."No.");
END;
LOCAL PROCEDURE UpdateRecord@92(FieldName@1000 : Text[100]);
VAR
FieldRef@1001 : FieldRef;
BEGIN
GetFieldValue(FieldRef,FieldName);
GET("Document Type","No.");
CASE FieldName OF
FIELDCAPTION("Shipment Date"):
"Shipment Date" := FieldRef.VALUE;
FIELDCAPTION("Currency Factor"):
"Currency Factor" := FieldRef.VALUE;
FIELDCAPTION("Transaction Type"):
"Transaction Type" := FieldRef.VALUE;
FIELDCAPTION("Transport Method"):
"Transport Method" := FieldRef.VALUE;
FIELDCAPTION("Exit Point"):
"Exit Point" := FieldRef.VALUE;
FIELDCAPTION(Area):
Area := FieldRef.VALUE;
FIELDCAPTION("Transaction Specification"):
"Transaction Specification" := FieldRef.VALUE;
FIELDCAPTION("Shipping Agent Code"):
"Shipping Agent Code" := FieldRef.VALUE;
FIELDCAPTION("Shipping Agent Service Code"):
"Shipping Agent Service Code" := FieldRef.VALUE;
FIELDCAPTION("Shipping Time"):
"Shipping Time" := FieldRef.VALUE;
FIELDCAPTION("Prepayment %"):
"Prepayment %" := FieldRef.VALUE;
FIELDCAPTION("Requested Delivery Date"):
"Requested Delivery Date" := FieldRef.VALUE;
FIELDCAPTION("Promised Delivery Date"):
"Promised Delivery Date" := FieldRef.VALUE;
FIELDCAPTION("Outbound Whse. Handling Time"):
"Outbound Whse. Handling Time" := FieldRef.VALUE;
END;
END;
// End of the added lines.
BEGIN
END.
}
}
Forutsetninger
Du må ha én av de følgende programmene installert for å bruke denne hurtigreparasjonen:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1
Informasjon om fjerning
Du kan ikke fjerne denne hurtigreparasjonen.
Status
Microsoft har bekreftet at dette er et problem i Microsoft-produktene som er oppført i delen "Gjelder for".
Obs! Dette er en "RASKT PUBLISERE" artikkel opprettet direkte fra innenfor organisasjonen Microsoft Kundestøtte. Informasjonen i dette dokumentet tilbys som-er som svar på nye problemer. Som et resultat av hastigheten i å gjøre den tilgjengelig materialene kan inkludere typografiske feil, og den kunne bli revidert når som helst uten varsel. Se Vilkårene for Brukfor andre hensyn.