Applies ToDynamics NAV 2009

Ketika Anda mengirim faktur dan pembayaran normal jurnal atau berulang jurnal yang berisi dikurangkan pajak (VAT), non-dikurangi PPN dalam bahasa Portugis versi Microsoft Dynamics NAV 2009, Anda menerima pesan galat berikut:

"Transaksi tidak dapat diselesaikan karena akan menyebabkan inkonsistensi dalam tabel G L entri. Periksa mana dan bagaimana fungsi KONSISTEN digunakan dalam transaksi untuk mencari penyebab galat. Hubungi administrator sistem Anda. Tabel dapat ditandai sebagai tidak konsisten selama tugas lengkap, seperti posting. Hal ini mencegah data dimutakhirkan dengan benar."

Ikuti langkah-langkah di bagian perubahan kode untuk memecahkan masalah ini. Masalah ini terjadi di produk berikut ini:

  • Portugis versi Microsoft Dynamics NAV 2009 R2

  • Portugis versi Microsoft Dynamics NAV 2009 SP1

Hal ini karena jumlah tertentu dan % PPN D..Misalnya:1, 15% dari 0, 25 = 0,002875 dan DIBULATKAN ke 2 desimal adalah 0.Pada Codeunit 12 ada batasan untuk hanya posting jumlah <> 0, sehingga entri pajak (VAT) dilewati.

Pemecahan masalah

Informasi Hotfix

Sekarang tersedia hotfix yang didukung dari Microsoft. Namun, hanya ditujukan untuk memperbaiki masalah yang dijelaskan di artikel ini. Terapkan hanya ke sistem yang mengalami masalah khusus ini. Perbaikan terbaru ini dapat menerima pengujian tambahan. Oleh karena itu, jika Anda tidak terlalu dipengaruhi oleh masalah ini, kami sarankan Anda menunggu paket layanan Microsoft Dynamics NAV 2009 atau versi Microsoft Dynamics NAV berikutnya yang berisi perbaikan terbaru ini.Catatan Dalam kasus tertentu, biaya yang biasanya diadakan untuk panggilan mungkin dibatalkan apabila profesional dukungan teknis untuk Microsoft Dynamics dan produk-produk terkait dukungan menentukan bahwa pembaruan khusus akan memecahkan masalah Anda. Biaya dukungan biasa akan berlaku untuk pertanyaan dan masalah yang tidak termasuk pada pembaruan tertentu yang dimaksud dukungan tambahan.

Informasi penginstalan

Microsoft menyediakan contoh pemrogaman hanya untuk ilustrasi, tanpa garansi baik tersurat maupun tersirat. Ini mencakup, namun tidak terbatas pada, garansi yang tersirat dapat diperjualbelikan atau kesesuaian untuk tujuan tertentu. Artikel ini menganggap bahwa Anda sudah terbiasa dengan bahasa pemrograman yang ditunjukkan dan terbiasa dengan alat-alat yang digunakan untuk membuat dan prosedur debug. Teknisi dukungan Microsoft dapat membantu menjelaskan fungsionalitas prosedur tertentu. Namun, mereka tidak akan mengubah contoh tersebut untuk memberikan fungsionalitas tambahan atau menyusun prosedur untuk memenuhi persyaratan khusus Anda.Catatan Sebelum Anda menginstal perbaikan terbaru ini, verifikasi bahwa semua pengguna klien Microsoft Dynamics NAV log off sistem. Ini termasuk layanan Microsoft Dynamics NAV aplikasi Server (NAS). Anda harus klien hanya pengguna yang masuk saat Anda menerapkan perbaikan terbaru ini.Untuk menerapkan hotfix ini, Anda harus memiliki lisensi pengembang.Kami menyarankan bahwa akun pengguna di jendela login Windows atau jendela login Database ditetapkan id peran "SUPER" Jika account pengguna tidak dapat menetapkan ID peran "SUPER", Anda harus memverifikasi bahwa account pengguna yang memiliki izin berikut ini:

  • Ubah izin untuk objek yang Anda akan berubah.

  • Izin eksekusi untuk objek sistem objek ID 5210 dan sistem objek ID 9015objek.

Catatan Anda tidak harus memiliki hak untuk penyimpanan data kecuali jika Anda harus melakukan perbaikan data.

Perubahan kode

Catatan selalu menguji kode perbaikan di lingkungan yang dikontrol sebelum Anda menerapkan perbaikan komputer produksi. Sebelum menerapkan perubahan, silakan mengimpor semua SEPA pembaruan.Untuk mengatasi masalah ini, ikuti langkah-langkah berikut:

  1. Ubah kode di InsertVAT fungsi dalam Kejadian Jnl.-posting baris Codeunit (12) sebagai berikut:Kode yang ada 1

    ...VATDifferenceLCY@1013 : Decimal;        SrcCurrVATDifference@1014 : Decimal;      BEGIN        WITH GenJnlLine DO BEGIN...

    Penggantian kode 1

    ...VATDifferenceLCY@1013 : Decimal;        SrcCurrVATDifference@1014 : Decimal;// Add the following line.VATAmountTotal@1015 : Decimal;// End of the added line.      BEGIN        WITH GenJnlLine DO BEGIN...

    Kode yang ada 2

    ...GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);                              InsertGLEntry(TRUE);// Delete the following lines.VATPostingSetup.TESTFIELD("Return VAT account (Sales)");InitGLEntry(VATPostingSetup."Return VAT account (Sales)",//                        -GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100,-TempVATAmount,//                        -SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100,ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),TRUE,TRUE);InsertGLEntry(TRUE);// End of the deleted lines.                          END                        ELSE...

    Penggantian kode 2

    ...GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);                              InsertGLEntry(TRUE);                          END                        ELSE...

    Kode yang ada 3

    ...END                      ELSE// Delete the following lines.BEGINIF NOT GenJnlLine."UE Aquisition Not Accep." THEN BEGINVATPostingSetup.TESTFIELD("Purchase VAT Account");InitGLEntry(VATPostingSetup."Purchase VAT Account",GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);InsertGLEntry(TRUE);END;//-------- VATPostingSetup.TESTFIELD("Reverse Chrg. VAT Acc.");InitGLEntry(VATPostingSetup."Reverse Chrg. VAT Acc.",//                    -GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100,//                    ROUND(-GLEntryVATAmount - VATBase * VATPostingSetup."VAT N.D. %" / 100),ROUND((- VATBase * VATPostingSetup."VAT D. %" / 100) - (VATBase * VATPostingSetup."VAT N.D. %" / 100)),//                    -SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100,ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),TRUE,TRUE);// End of the deleted lines.                          InsertGLEntry(TRUE);                        END;...

    Penggantian kode 3

    ...END                      ELSE// Add the following lines.IF NOT GenJnlLine."UE Aquisition Not Accep." THEN BEGINVATPostingSetup.TESTFIELD("Purchase VAT Account");InitGLEntry(VATPostingSetup."Purchase VAT Account",GLEntryVATAmount,SrcCurrGLEntryVATAmt,TRUE,TRUE);// End of the added lines.                          InsertGLEntry(TRUE);                        END;...

    Ada kode 4

    ...END;          END;        END;      END;...

    Penggantian kode 4

    ...  END;          END;// Add the following lines.IF IsPurchaseReverseChargeVAT(UnrealizedVAT) THENIF "Document Type"= "Document Type"::"Credit Memo" THEN BEGINIF (NOT GenJnlLine."UE Aquisition Not Accep.") AND (TempVATAmount <> 0) THEN BEGINVATPostingSetup.TESTFIELD("Return VAT account (Sales)");InitGLEntry(VATPostingSetup."Return VAT account (Sales)",-TempVATAmount,ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),TRUE,TRUE);InsertGLEntry(TRUE);END;END ELSE BEGINVATAmountTotal := ROUND((- VATBase * VATPostingSetup."VAT D. %" / 100) - (VATBase * VATPostingSetup."VAT N.D. %" / 100));IF VATAmountTotal <> 0 THEN BEGIN VATPostingSetup.TESTFIELD("Reverse Chrg. VAT Acc.");InitGLEntry(VATPostingSetup."Reverse Chrg. VAT Acc.",VATAmountTotal,ROUND(-SrcCurrGLEntryVATAmt - SrcCurrVATBase * VATPostingSetup."VAT N.D. %" / 100),TRUE,TRUE);InsertGLEntry(TRUE);END;END;// End of the added lines.        END;      END;...
  2. Ubah kode di IsPurchaseReverseChargeVAT fungsi dalam Kejadian Jnl.-posting baris Codeunit (12) sebagai berikut:Kode yang ada

    ...END;      BEGIN      END....

    Penggantian kode

    ...END;// Add the following lines.LOCAL PROCEDURE IsPurchaseReverseChargeVAT@1110015(UnrealizedVAT@1110000 : Boolean) : Boolean;BEGINEXIT((GenJnlLine."Gen. Posting Type" = GenJnlLine."Gen. Posting Type"::Purchase) AND (NOT UnrealizedVAT) AND(VATPostingSetup."VAT Calculation Type" = VATPostingSetup."VAT Calculation Type"::"Reverse Charge VAT" ));END;// End of the added lines.      BEGIN      END....

Prasyarat

Anda harus memiliki salah satu produk berikut ini diinstal untuk menerapkan perbaikan terbaru ini:

  • Portugis versi Microsoft Dynamics NAV 2009 R2

  • Portugis versi Microsoft Dynamics NAV 2009 SP1

Informasi penghapusan

Anda tidak dapat menghapus hotfix ini.

Status

Microsoft telah memastikan bahwa ini merupakan masalah di dalam produk Microsoft sebagaimana tercantum di bagian "Berlaku untuk".

Catatan Ini adalah artikel "Penerbitan cepat" dibuat langsung dari dalam organisasi dukungan Microsoft. Informasi yang terkandung di dalamnya disediakan sebagai tanggapan masalah yang muncul. Sebagai akibat dari kecepatan untuk menjadikannya tersedia, materi dapat mengandung kesalahan ketik dan dapat direvisi setiap saat tanpa pemberitahuan. Lihat Ketentuanuntuk pertimbangan lainnya.

Perlu bantuan lainnya?

Ingin opsi lainnya?

Jelajahi manfaat langganan, telusuri kursus pelatihan, pelajari cara mengamankan perangkat Anda, dan banyak lagi.

Komunitas membantu Anda bertanya dan menjawab pertanyaan, memberikan umpan balik, dan mendengar dari para ahli yang memiliki pengetahuan yang luas.