Sümptomid

Kui loote rakenduses Microsoft Dynamics nav-i 2009 ettemaksu arve, kuvatakse järgmine tõrketeade:

Ettemaksu ei ". Rea väärtus peab olema ostu päisesse."

See juhtub ainult seadistuse pole arvu seeria ettemaksu arve. Järgige juhiseid koodi muudatusi selle probleemi lahendamiseks jaotisse. See probleem ilmneb järgmiste toodetega:

  • Microsoft Dynamics nav-i 2009 R2

  • Microsoft Dynamics nav-i 2009 SP1

Lahendus

Kiirparanduse teave

Lasknud välja toetatava käigultparanduse on nüüd Microsoftilt saadaval. Kuid see on ette nähtud ainult selles artiklis kirjeldatud probleemi kõrvaldamiseks. Rakendage seda ainult süsteemides, kus ilmneb see konkreetne probleem. Seda käigultparandust võidakse täiendavalt testida. Seega, kui probleem teie tööd tõsiselt ei kahjusta, soovitame oodata järgmist hoolduspaketti Microsoft Dynamics nav-i 2009 või järgmise Microsoft Dynamics nav-i versiooni, mis sisaldab seda kiirparandust.

Märkus. Erijuhtudel kulud, mis tekivad teatud palub tühistada saab kui tehniline toetus Professional Microsoft Dynamics ja nendega seotud toodete leiab, et mõni konkreetne värskendus lahendab teie probleemi. Tavaline tugiteenuste kohaldatakse täiendavat tugiteenust vajavatele küsimustele ning probleemidele, mis pole lahendatavad konkreetse värskenduse installimisega.

Installiteave

Microsoft pakub programmeerimisnäiteid ainult artikli illustreerimiseks ilma igasuguse otsese või kaudse garantiita. See hõlmab, kuid ei piirdu kaudseid garantiisid turustatavuse või kindlaks otstarbeks sobivusega. See artikkel eeldab, et olete demonstreeritava programmeerimiskeelega programmeerimise keel ning luua protseduuride ja silumiseks kasutatavate tööriistadega tuttav. Microsofti tugitehnikud võivad aidata mõne konkreetse protseduuri talitlust selgitada. Siiski ei muuda nad neid näiteid lisafunktsioonide pakkumiseks ega Koosta vastavaid protseduure teie konkreetsetele nõuetele.

Märkus. Enne selle kiirparanduse installimist veenduge, et kõik Microsoft Dynamics nav-i kliendi kasutajat sisse loginud süsteem välja. See hõlmab Microsoft Dynamics nav-i rakenduste Server (NAS) teenuseid. Peaks olema ainult kliendi kasutaja on sisse logitud, kui otsustate seda käigultparandust.

Selle kiirparanduse rakendamiseks peab teil olema arendaja litsentsi.

Soovitame Windowsi sisselogimise aken või aken andmebaasi logimine kasutajakonto määrata "SUPER" rolli ID. Kui "SUPER" rolli ID-d ei saa määratud kasutajakonto, peate veenduma, et kasutaja konto on järgmised õigused:

  • Sa muutuvad objekti Muuda õigusi.

  • Käivita luba süsteemi objekti ID 5210 objekti ja süsteemi objekti ID 9015

    objekti.

Märkus. Teil pole õigust andmeid talletab enne, kui olete andmete parandamiseks.

Koodi muudatusi

Märkus. Alati test koodi lahendab kontrollitavas keskkonnas enne rakendamist tootmine arvutite parandused.

Selle probleemi lahendamiseks toimige järgmiselt.

  1. Tabelis müügi päise (36) koodi muutmiseks järgmiselt:
    Kood 1

    ... IF "Prepayment No. Series" <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(SalesSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series");
    // End of the deleted line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

    Kood 1

    ...IF "Prepayment No. Series" <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series");
    // End of the added line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

    Kood 2

    ...SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    IF NoSeriesMgt.LookupSeries(SalesSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series") THEN
    // End of the deleted line.

    VALIDATE("Prepayment No. Series");
    Rec := SalesHeader;
    END;
    ...

    Asendamine kood 2

    ...
    SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series") THEN
    // End of the added line.

    VALIDATE("Prepayment No. Series");
    Rec := SalesHeader;
    END;
    ...

    Kood 3

    ... IF "Prepmt. Cr. Memo No." <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(SalesSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No.");
    // End of the deleted line.

    END;
    TESTFIELD("Prepmt. Cr. Memo No.",'');
    END;
    ...

    Asendamine kood 3

    ... IF "Prepmt. Cr. Memo No." <> '' THEN BEGIN
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series");
    // End of the added line.

    END;
    TESTFIELD("Prepmt. Cr. Memo No.",'');
    END;
    ...

    Kood 4

    ...SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following lines.
    IF NoSeriesMgt.LookupSeries(GetPostingNoSeriesCode,"Prepmt. Cr. Memo No.") THEN
    VALIDATE("Prepmt. Cr. Memo No.");
    // End of the deleted lines.

    Rec := SalesHeader;
    END;
    END;
    ...

    Asendamine kood 4

    ...SalesHeader := Rec;
    SalesSetup.GET;
    SalesSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following lines.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series") THEN
    VALIDATE("Prepmt. Cr. Memo No. Series");
    // End of the added lines.

    Rec := SalesHeader;
    END;
    END;
    ...
  2. Muuta koodi GetPostingPrepaymentNoSeriesCo funktsiooni tabeli Müügi päis (36) järgmiselt:
    Kood

    ...EXIT(SalesSetup."Posted Invoice Nos.");
    END;

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...

    Eemaldamise teave

    ... EXIT(SalesSetup."Posted Invoice Nos.");
    END;

    // Add the following lines.
    LOCAL PROCEDURE GetPostingPrepaymentNoSeriesCo@59() : Code[10];
    BEGIN
    IF "Document Type" IN ["Document Type"::"Return Order","Document Type"::"Credit Memo"] THEN
    EXIT(SalesSetup."Posted Prepmt. Cr. Memo Nos.");
    EXIT(SalesSetup."Posted Prepmt. Inv. Nos.");
    END;
    // End of the added lines.

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...
  3. Ostutellimuse päise tabelis (38) koodi muutmiseks järgmiselt:
    Kood 1

    ...IF "Prepayment No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(PurchSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series");
    // End of the deleted line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

    Kood 1

    ...IF "Prepayment No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series");
    // End of the added line.

    END;
    TESTFIELD("Prepayment No.",'');
    END;
    ...

    Kood 2

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Delete the following line.
    IF NoSeriesMgt.LookupSeries(PurchSetup."Posted Prepmt. Inv. Nos.","Prepayment No. Series") THEN
    // End of the deleted line.

    VALIDATE("Prepayment No. Series");
    Rec := PurchHeader;
    END;
    ...

    Asendamine kood 2

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Inv. Nos.");

    // Add the following line.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepayment No. Series") THEN
    // End of the added line.

    VALIDATE("Prepayment No. Series");
    Rec := PurchHeader;
    END;
    ...

    Kood 3

    ...IF "Prepmt. Cr. Memo No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following line.
    NoSeriesMgt.TestSeries(PurchSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No. Series");
    // End of the deleted line.

    END;

    // Delete the following line.
    TESTFIELD("Prepmt. Cr. Memo No. Series",'');
    // End of the deleted line.

    END;

    OnLookup=BEGIN
    ...

    Asendamine kood 3

    ...IF "Prepmt. Cr. Memo No. Series" <> '' THEN BEGIN
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following line.
    NoSeriesMgt.TestSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series");
    // End of the added line.

    END;

    // Add the following line.
    TESTFIELD("Prepmt. Cr. Memo No.",'');
    // End of the added line.

    END;

    OnLookup=BEGIN
    ...

    Kood 4

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Delete the following line.
    IF NoSeriesMgt.LookupSeries(PurchSetup."Posted Prepmt. Cr. Memo Nos.","Prepmt. Cr. Memo No. Series") THEN
    // End of the deleted line.

    VALIDATE("Prepmt. Cr. Memo No. Series");
    Rec := PurchHeader;
    END;
    ...

    Asendamine kood 4

    ...PurchHeader := Rec;
    PurchSetup.GET;
    PurchSetup.TESTFIELD("Posted Prepmt. Cr. Memo Nos.");

    // Add the following line.
    IF NoSeriesMgt.LookupSeries(GetPostingPrepaymentNoSeriesCo,"Prepmt. Cr. Memo No. Series") THEN
    // End of the added line.

    VALIDATE("Prepmt. Cr. Memo No. Series");
    Rec := PurchHeader;
    END;
    ...
  4. Muuda koodi GetPostingPrepaymentNoSeriesCo funktsioon tabeli Ostu päis (38) järgmiselt:
    Kood

    ...EXIT(PurchSetup."Posted Invoice Nos.");
    END;

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...

    Eemaldamise teave

    ...EXIT(PurchSetup."Posted Invoice Nos.");
    END;

    // Add the following lines.
    LOCAL PROCEDURE GetPostingPrepaymentNoSeriesCo@37() : Code[10];
    BEGIN
    IF "Document Type" IN ["Document Type"::"Return Order","Document Type"::"Credit Memo"] THEN
    EXIT(PurchSetup."Posted Prepmt. Cr. Memo Nos.");
    EXIT(PurchSetup."Posted Prepmt. Inv. Nos.");
    END;
    // End of the added lines.

    LOCAL PROCEDURE TestNoSeriesDate@40(No@1000 : Code[20];NoSeriesCode@1001 : Code[10];NoCapt@1002 : Text[1024];NoSeriesCapt@1004 : Text[1024]);
    VAR
    NoSeries@1005 : Record 308;
    ...

Eeltingimused

Teil peab olema üks selle kiirparanduse installinud järgmisi tooteid:

  • Microsoft Dynamics nav-i 2009 R2

  • Microsoft Dynamics nav-i 2009 SP1

Eemaldamise teave

See käigultparandus ei saa eemaldada.

Olek

Microsoft on kinnitanud, et see probleem esineb jaotises "Kehtib järgmiste toodete kohta" loetletud Microsofti toodetel.

Märkus. See on "Kiire avaldamise" artikli loonud otse Microsofti tugiteenuse pakkujalt. Siintoodud teave on esitatud lähtudes-olemasoleval kujul vastusena ilmnenud probleemidele. Kiire avaldamise materjalides esineda trükivigu ja võidakse muuta ette teatamata. Vt Kasutustingimusedmuid kaalutlusi.

Kas vajate veel abi?

Täiendage oma oskusi
Tutvuge koolitusmaterjalidega
Kasutage uusi funktsioone enne teisi
Liitu Microsofti Insideri programmis osalejad

Kas sellest teabest oli abi?

Kui rahul te keelekvaliteediga olete?
Mis mõjutas teie hinnangut?

Täname tagasiside eest!

×