Bu makale, Microsoft Dynamics NAV'da aşağıdaki ülke ve dil yerel ayarları için geçerlidir.
- Fransızca (İsviçre) (fr-ch)
- Almanca (İsviçre) (gr-ch)
- İtalyanca (İsviçre) (BT-ch)
Belirtiler
Başlangıç-Toplam türü satır ve bir Bitiş-Toplam türü satır ın İsviçre sürümü Microsoft Dynamics NAV 2009 olan bir satış faturası deftere nakledildikten sonra deftere nakledilen faturanın Bitiş-Toplam türü satırda KDV dahil tutar değeri yanlış.
Bu sorun aşağıdaki ürünlerde oluşur:
Bu sorun aşağıdaki ürünlerde oluşur:
- Microsoft Dynamics NAV 2009 R2'ın İsviçre sürümü
- Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)'ın İsviçre sürümü
Çözüm
Düzeltme bilgileri
Artık Microsoft tarafından desteklenen bir düzeltme sağlanmaktadır. Ancak bunun yalnızca bu makalede anlatılan sorunu düzeltmesi amaçlanmıştır. Yalnızca bu özel sorunla karşılaşmış olan sistemlere uygulayın. Bu düzeltme ek sınama uygulanabilir. Bu nedenle, bu sorundan ciddi bir şekilde etkilenmiyorsanız, Microsoft Dynamics NAV sonraki hizmet paketini veya, bu düzeltmeyi içeren bir sonraki Microsoft Dynamics NAV sürümü için beklemek öneririz.Not: Özel durumlarda, destek aramaları teknik destek uzmanı Microsoft Dynamics ve ilgili ürünlere yönelik iptal edilebilir çözeceğini giderleri belirleyen belirli bir güncelleştirmenin sorununuzu. Ek destek sorularına ve söz konusu güncelleştirme için geçerli olmayan sorunlara normal destek ücretleri uygulanır.
Yükleme bilgileri
Microsoft, programlama örneklerini yalnızca gösterim amacıyla zımni veya açık garanti olmadan sağlar. Bu, satılabilirlik veya belirli bir amaca uygunluk açısından zımni garantileri içerir ancak bunlarla sınırlı değildir. Bu makale, gösterilen programlama dilini, yordamları oluşturmak ve yordamlardan hata ayıklamak için kullanılan araçları bildiğinizi varsayar. Microsoft destek mühendisleri belirli bir yordamın işlevselliğinin açıklanmasına yardımcı olabilirler, ancak ilave işlevsellik sağlamak için bu örnekleri değiştirmezler veya belirli gereksinimlerinizi karşılayacak şekilde yordamları yapılandırmazlar.Not: Bu düzeltmeyi yüklemeden önce tüm Microsoft Navision istemcisi kullanıcılar sistem oturum doğrulayın. Bu, Microsoft Navision uygulama Hizmetleri (NAS) istemci kullanıcıları içerir. Bu düzeltmeyi uyguladığınızda yalnızca istemci kullanıcının oturum açmış olması gerekir.
Bu düzeltmeyi uygulamak için bir geliştirici lisansı olması gerekir.
Kullanıcı hesabının Windows oturumu açma penceresini veya veritabanı oturumu açma penceresi "Süper" rol kimliği atanması öneririz Kullanıcı hesabı "Süper" rol Kimliği atanamaz, kullanıcı hesabı aşağıdaki izinlere sahip olduğunu doğrulamanız gerekir:
- Nesnenin, değiştirme değişiklik yapma izni.
- Execute izni Sistem nesne kimliği 5210 nesnenin ve nesne kimliği 9015 sistem nesnesi için.
Not: Veri onarım gerçekleştirmek zorunda sürece veri depoları haklarına sahip olmanız gerekmez.
Kod değişiklikleri
Not: Her zaman, uygulamadan önce test kodu denetimli bir ortamda üretim bilgisayarlarınıza düzeltmeler giderir.Bu sorunu gidermek için şu adımları izleyin:
- Deftere nakledilen satış faturası alt formu (133) KDV dahil tutar - OnFormat tetikleyici kodu aşağıdaki gibi değiştirin:
Varolan koduKod değiştirme...
IF (Type = Type::"End-Total") AND ("Subtotal net" <> 0) THEN BEGIN
// Delete the following line.
Text := FORMAT("Subtotal net",0,'<Sign><Integer Thousand><Decimals,3>');
CurrForm."Amount Including VAT".UPDATEFONTBOLD := TRUE;
END;
......
IF (Type = Type::"End-Total") AND ("Subtotal net" <> 0) THEN BEGIN
// Add the following line.
Text := FORMAT(CalcTotalAmountIncludingVAT("Document No.","Line No."),0,'<Sign><Integer Thousand><Decimals,3>');
CurrForm."Amount Including VAT".UPDATEFONTBOLD := TRUE;
END;
... - Deftere nakledilen satış faturası alt formu (133) formunda yeni bir yerel CalcTotalAmountIncludingVAT işlev oluşturma işlevi oluşturmak için şu adımları izleyin:
- CalcTotalAmountIncludingVAT işlevinde deftere nakledilen satış faturası alt formu (133) formunda yeni bir yerel parametre ekleyin ve sonra parametre aşağıdaki gibi belirtin:
- Var: No
- Adı: DocumentNo
- Veri türü: kod
- Uzunluk: 20
- CalcTotalAmountIncludingVAT işlevinde deftere nakledilen satış faturası alt formu (133) formunda yeni bir yerel parametre ekleyin ve sonra parametre aşağıdaki gibi belirtin:
- Var: No
- Adı: EndLineNo
- Veri türü: Tamsayı
- Yeni bir dönüş değeri deftere nakledilen satış faturası alt formu (133) içinde CalcTotalAmountIncludingVAT işlevini ekleyin ve sonra dönüş değeri aşağıdaki gibi belirtin:
- Adı: AmountIncludingVAT
- Dönüş türü: ondalık
- Deftere nakledilen satış faturası alt formu (133) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel deðiþken ekleyin ve sonra değişken aşağıdaki gibi belirtin:
- Adı: SalesInvoiceLine
- Veri türü: kayıt
- Alt tür: Satış Fatura satırı
- Deftere nakledilen satış faturası alt formu (133) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel deðiþken ekleyin ve sonra değişken aşağıdaki gibi belirtin:
- Adı: Say
- Veri türü: Tamsayı
- Deftere nakledilen satış faturası alt formu (133) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel deðiþken ekleyin ve sonra değişken aşağıdaki gibi belirtin:
- Adı: BeginLineNo
- Veri türü: Tamsayı
- Deftere nakledilen satış faturası alt formu (133) CalcTotalAmountIncludingVAT işlevinde aşağıdaki satırları ekleyin:
PROCEDURE CalcTotalAmountIncludingVAT(DocumentNo : Code[20];EndLineNo : Integer) AmountIncludingVAT : Decimal
Count := -1;
BeginLineNo := 0;
SalesInvoiceLine.RESET;
SalesInvoiceLine.SETRANGE("Document No.",DocumentNo);
SalesInvoiceLine.SETRANGE("Line No.",0,EndLineNo);
IF SalesInvoiceLine.FINDLAST THEN
REPEAT
IF SalesInvoiceLine.Type = SalesInvoiceLine.Type::"Begin-Total" THEN
IF Count = 0 THEN
BeginLineNo := SalesInvoiceLine."Line No."
ELSE
Count := Count - 1
ELSE
IF SalesInvoiceLine.Type = SalesInvoiceLine.Type::"End-Total" THEN
Count := Count + 1;
UNTIL (SalesInvoiceLine.NEXT(-1) = 0) OR (BeginLineNo <> 0);
SalesInvoiceLine.SETRANGE("Line No.",BeginLineNo,EndLineNo);
SalesInvoiceLine.CALCSUMS("Amount Including VAT");
AmountIncludingVAT := SalesInvoiceLine."Amount Including VAT";CalcTotalAmountIncludingVAT(DocumentNo : Code[20];EndLineNo : Integer) AmountIncludingVAT : Decimal
Count := -1;
BeginLineNo := 0;
SalesInvoiceLine.RESET;
SalesInvoiceLine.SETRANGE("Document No.",DocumentNo);
SalesInvoiceLine.SETRANGE("Line No.",0,EndLineNo);
IF SalesInvoiceLine.FINDLAST THEN
REPEAT
IF SalesInvoiceLine.Type = SalesInvoiceLine.Type::"Begin-Total" THEN
IF Count = 0 THEN
BeginLineNo := SalesInvoiceLine."Line No."
ELSE
Count := Count - 1
ELSE
IF SalesInvoiceLine.Type = SalesInvoiceLine.Type::"End-Total" THEN
Count := Count + 1;
UNTIL (SalesInvoiceLine.NEXT(-1) = 0) OR (BeginLineNo <> 0);
SalesInvoiceLine.SETRANGE("Line No.",BeginLineNo,EndLineNo);
SalesInvoiceLine.CALCSUMS("Amount Including VAT");
AmountIncludingVAT := SalesInvoiceLine."Amount Including VAT";
- CalcTotalAmountIncludingVAT işlevinde deftere nakledilen satış faturası alt formu (133) formunda yeni bir yerel parametre ekleyin ve sonra parametre aşağıdaki gibi belirtin:
- Deftere nakledilen satış iade faturası alt formu (135) KDV dahil tutar - OnFormat tetikleyici kodu aşağıdaki gibi değiştirin:
Varolan koduKod değiştirme...
IF (Type = Type::"End-Total") AND ("Subtotal net" <> 0) THEN BEGIN
// Delete the following line.
Text := FORMAT("Subtotal net",0,'<Sign><Integer Thousand><Decimals,3>');
CurrForm."Amount Including VAT".UPDATEFONTBOLD := TRUE;
END;
......
IF (Type = Type::"End-Total") AND ("Subtotal net" <> 0) THEN BEGIN
// Add the following line.
Text := FORMAT(CalcTotalAmountIncludingVAT("Document No.","Line No."),0,'<Sign><Integer Thousand><Decimals,3>');
CurrForm."Amount Including VAT".UPDATEFONTBOLD := TRUE;
END;
... - Deftere nakledilen satış iade faturası alt formu (135) içinde yeni bir yerel CalcTotalAmountIncludingVAT işlev oluşturma işlevi oluşturmak için şu adımları izleyin:
- Deftere nakledilen satış iade faturası alt formu (135) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel parametre ekleyin ve sonra da parametre aşağıdaki gibi belirtin:
- Var: No
- Adı: DocumentNo
- Veri türü: kod
- Uzunluk: 20
- Deftere nakledilen satış iade faturası alt formu (135) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel parametre ekleyin ve sonra da parametre aşağıdaki gibi belirtin:
- Var: No
- Adı: EndLineNo
- Veri türü: Tamsayı
- Yeni bir dönüş değeri deftere nakledilen satış iade faturası alt formu (135) içinde CalcTotalAmountIncludingVAT işlevini ekleyin ve sonra dönüş değeri aşağıdaki gibi belirtin:
- Adı: AmountIncludingVAT
- Dönüş türü: ondalık
- Deftere nakledilen satış iade faturası alt formu (135) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel deðiþken ekleyin ve sonra değişken aşağıdaki gibi belirtin:
- Adı: SalesCrMemoLine
- Veri türü: kayıt
- Alt tür: Satış İade Fat.
- Deftere nakledilen satış iade faturası alt formu (135) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel deðiþken ekleyin ve sonra değişken aşağıdaki gibi belirtin:
- Adı: Say
- Veri türü: Tamsayı
- Deftere nakledilen satış iade faturası alt formu (135) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel deðiþken ekleyin ve sonra değişken aşağıdaki gibi belirtin:
- Adı: BeginLineNo
- Veri türü: Tamsayı
- Deftere nakledilen satış iade faturası alt formu (135) CalcTotalAmountIncludingVAT işlevinde aşağıdaki satırları ekleyin:
PROCEDURE CalcTotalAmountIncludingVAT(DocumentNo : Code[20];EndLineNo : Integer) AmountIncludingVAT : Decimal
Count := -1;
BeginLineNo := 0;
SalesCrMemoLine.RESET;
SalesCrMemoLine.SETRANGE("Document No.",DocumentNo);
SalesCrMemoLine.SETRANGE("Line No.",0,EndLineNo);
IF SalesCrMemoLine.FINDLAST THEN
REPEAT
IF SalesCrMemoLine.Type = SalesCrMemoLine.Type::"Begin-Total" THEN
IF Count = 0 THEN
BeginLineNo := SalesCrMemoLine."Line No."
ELSE
Count := Count - 1
ELSE
IF SalesCrMemoLine.Type = SalesCrMemoLine.Type::"End-Total" THEN
Count := Count + 1;
UNTIL (SalesCrMemoLine.NEXT(-1) = 0) OR (BeginLineNo <> 0);
SalesCrMemoLine.SETRANGE("Line No.",BeginLineNo,EndLineNo);
SalesCrMemoLine.CALCSUMS("Amount Including VAT");
AmountIncludingVAT := SalesCrMemoLine."Amount Including VAT";CalcTotalAmountIncludingVAT(DocumentNo : Code[20];EndLineNo : Integer) AmountIncludingVAT : Decimal
- Deftere nakledilen satış iade faturası alt formu (135) CalcTotalAmountIncludingVAT işlevinde yeni bir yerel parametre ekleyin ve sonra da parametre aşağıdaki gibi belirtin:
Önkoşullar
Bu düzeltmeyi uygulamak için aşağıdaki ürünlerden birine sahip olmalıdır:- Microsoft Dynamics NAV 2009 R2'ın İsviçre sürümü
- Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)'ın İsviçre sürümü
Kaldırma bilgileri
Bu düzeltmeyi kaldıramazsınız.Durum
Microsoft bu sorunun "Aşağıdakilere Uygulanır" bölümünde listelenen Microsoft ürünlerinde bulunduğunu onaylamıştır.
Not: Bu, doğrudan Microsoft destek kuruluşu bünyesinde oluşturulan bir "HIZLI YAYIN" makalesidir. Burada yer alan bilgiler, oluşan sorunlara yanıt olarak olduğu gibi sağlanmıştır. Makale hızla kullanıma sunulduğu için materyallerde yazım hataları olabilir ve materyaller bildirilmeksizin herhangi bir zamanda revize edilebilir. Diğer konular için bkz. Kullanım koşulları.