ฟังก์ชันการรวม/ไม่รวมการปิดรายการบัญชีทำงาน ใน SP1 2009 นำทางของ Dynamics Microsoft และ ใน Microsoft Dynamics NAV 2009 R2


บทความนี้นำไปใช้กับ Microsoft Dynamics NAV สำหรับตำแหน่งที่ตั้งภาษาทั้งหมด

อาการ


ใน Microsoft Dynamics NAV 2009 Service Pack 1 (SP1) หรือ ใน Microsoft Dynamics NAV 2009 R2 คุณพบปัญหาเกี่ยวกับฟังก์ชันการรวม/ไม่รวมการปิดรายการต่อไปนี้:
  • แบบฟอร์มยอดดุล G/L (414) แสดงค่าที่ไม่ถูกต้องเมื่อคุณรันฟังก์ชันการปิดรายการบัญชีโดยการตั้งค่าตัวกรองข้อมูลจาก "ปิดรอบระยะเวลา" กับ "ไม่ปิดรอบระยะเวลา"
  • งบทดลอง แพร่กระจายรอบระยะเวลารายงาน (10026) แสดงค่าที่ไม่ถูกต้องเมื่อรอบระยะเวลาจาก "ปิดรอบระยะเวลา" กับ "ไม่ปิดรอบระยะเวลา" ประกอบด้วยคอลัมน์รายงาน

การแก้ปัญหา


ข้อมูลโปรแกรมแก้ไขด่วน

โปรแกรมแก้ไขด่วนจะพร้อมใช้งานได้ในขณะนี้จาก Microsoft อย่างไรก็ตาม มีเป้าหมายเพียงเพื่อการแก้ไขปัญหาที่อธิบายไว้ในบทความนี้ นำวิธีนี้ไปใช้กับระบบที่ประสบกับปัญหาที่เฉพาะเจาะจงเท่านั้น โปรแกรมแก้ไขด่วนนี้อาจได้รับการทดสอบเพิ่มเติม ดังนั้น ถ้าคุณจะไม่รุนแรงได้รับผลกระทบจากปัญหานี้ เราขอแนะนำให้ คุณรอ service pack ถัดไปของ Microsoft Dynamics NAV 2009 หรือเวอร์ชันถัดไป Microsoft Dynamics NAV ที่ประกอบด้วยโปรแกรมแก้ไขด่วนนี้

หมายเหตุ ในกรณีพิเศษ ค่าธรรมเนียมค่าใช้จ่ายสำหรับการสนับสนุนโทรศัพท์อาจถูกยกเลิกถ้า Technical Support Professional สำหรับ Microsoft Dynamics และผลิตภัณฑ์ที่เกี่ยวข้องตรวจพบว่าการปรับปรุงเฉพาะจะแก้ปัญหาของคุณ ค่าใช้จ่ายในการสนับสนุนตามปกติจะใช้กับคำถามและปัญหาในการสนับสนุนเพิ่มเติมซึ่งไม่สอดคล้องตามเกณฑ์สำหรับโปรแกรมปรับปรุงเฉพาะที่เกี่ยวข้อง



ข้อมูลการติดตั้ง

Microsoft ให้ตัวอย่างการเขียนโปรแกรมไว้สำหรับประกอบการอธิบายเท่านั้นโดยไม่มีการรับประกันไม่ว่าจะโดยชัดแจ้งหรือโดยนัย กรณีนี้รวมถึงแต่มิได้จำกัดเพียงแค่การการรับประกันโดยนัยเกี่ยวกับการจำหน่ายเป็นสินค้าหรือความเหมาะสำหรับวัตถุประสงค์เฉพาะ บทความนี้ตั้งสมมติฐานว่าคุณมีความคุ้นเคยกับภาษาการเขียนโปรแกรมที่กำลังแสดงและคุ้นเคยกับเครื่องมือที่ใช้ใน การสร้างและแก้จุดบกพร่องของขั้นตอนการดำเนินการ วิศวกรฝ่ายสนับสนุนของ Microsoft สามารถช่วยอธิบายฟังก์ชันการทำงานของกระบวนการเฉพาะได้ แต่จะไม่ปรับเปลี่ยนตัวอย่างเหล่านี้เพื่อให้ฟังก์ชันการทำงานเพิ่มเติมหรือสร้างกระบวนงานเพื่อตอบสนองความต้องการเฉพาะของคุณ

หมายเหตุ ก่อนที่คุณติดตั้งโปรแกรมแก้ไขด่วนนี้ โปรดตรวจสอบว่า ผู้ใช้ไคลเอนต์ของ Microsoft Navision ทั้งหมดเข้าสู่ระบบออกจากระบบ ข้อมูลนี้รวมถึงผู้ใช้ไคลเอ็นต์บริการแอพลิเคชัน Navision Microsoft (NAS) คุณควรไคลเอ็นต์เฉพาะผู้ใช้ที่เข้าสู่ระบบเมื่อคุณใช้โปรแกรมแก้ไขด่วนนี้

เมื่อต้องการใช้โปรแกรมแก้ไขด่วนนี้ คุณต้องมีสิทธิ์การใช้งานสำหรับนักพัฒนา

เราขอแนะนำว่า บัญชีผู้ใช้ ในหน้าต่างล็อกอินของ Windows หรือ ในหน้าต่างล็อกอินฐานข้อมูลสามารถกำหนดรหัสการเข้าถึงข้อมูล "ขั้นสูง" ถ้าบัญชีผู้ใช้ไม่สามารถกำหนดรหัสการบทบาท "SUPER" คุณต้องตรวจสอบว่า บัญชีผู้ใช้มีสิทธิ์ต่อไปนี้:
  • สิทธิ์การปรับเปลี่ยนสำหรับออปเจ็กต์ที่คุณจะสามารถเปลี่ยน
  • สิทธิ์ Execute สำหรับออบเจ็กต์5210 รหัสวัตถุของระบบและ สำหรับออบเจ็กต์ระบบ 9015 ID ของวัตถุ


หมายเหตุ คุณไม่จำเป็นต้องมีสิทธิ์ไปยังร้านค้าข้อมูลยกเว้นว่าคุณจำเป็นต้องซ่อมแซมข้อมูล

การเปลี่ยนแปลงรหัส

หมายเหตุ เสมอทดสอบรหัสแก้ไขในสภาพแวดล้อมการควบคุมก่อนที่คุณนำไปใช้แก้ไขปัญหากับคอมพิวเตอร์ของคุณผลิต
เมื่อต้องการแก้ไขปัญหานี้ เปลี่ยนแปลงรหัสนี้ในฟังก์ชันFindPeriodในแบบฟอร์มยอดดุล G/L (414) เป็นดังนี้:
รหัสที่มีอยู่
... IF ClosingEntryFilter = ClosingEntryFilter::Exclude THEN BEGIN
AccountingPeriod.SETCURRENTKEY("New Fiscal Year");
AccountingPeriod.SETRANGE("New Fiscal Year",TRUE);
IF GETRANGEMIN("Date Filter") = 0D THEN
AccountingPeriod.SETRANGE("Starting Date",0D,GETRANGEMAX("Date Filter"))

// Delete the following lines.
ELSE
AccountingPeriod.SETRANGE(
"Starting Date",
GETRANGEMIN("Date Filter") + 1,
GETRANGEMAX("Date Filter"));
// End of the deleted lines.

IF AccountingPeriod.FIND('-') THEN
REPEAT
SETFILTER(
"Date Filter",GETFILTER("Date Filter") + '&<>%1',
CLOSINGDATE(AccountingPeriod."Starting Date" - 1));
...
รหัสแทน
... IF ClosingEntryFilter = ClosingEntryFilter::Exclude THEN BEGIN
AccountingPeriod.SETCURRENTKEY("New Fiscal Year");
AccountingPeriod.SETRANGE("New Fiscal Year",TRUE);
IF GETRANGEMIN("Date Filter") = 0D THEN
AccountingPeriod.SETRANGE("Starting Date",0D,GETRANGEMAX("Date Filter"))

// Add the following lines.
ELSE BEGIN
IF NOT (GETRANGEMIN("Date Filter") = NORMALDATE(GETRANGEMIN("Date Filter"))) THEN
AccountingPeriod.SETRANGE(
"Starting Date",
GETRANGEMIN("Date Filter") + 1,
GETRANGEMAX("Date Filter"))
ELSE
AccountingPeriod.SETRANGE(
"Starting Date",0D,
GETRANGEMIN("Date Filter") + 1);
END;
// End of the added lines.
...

ข้อกำหนดเบื้องต้น

คุณต้องมีหนึ่งผลิตภัณฑ์ต่อไปนี้ติดตั้งอยู่เพื่อใช้โปรแกรมแก้ไขด่วนนี้:
  • Microsoft Dynamics NAV 2009 Service Pack ที่ 1 (SP1)
  • Microsoft Dynamics NAV 2009 R2


ข้อมูลการเอาออก

คุณไม่สามารถเอาโปรแกรมแก้ไขด่วนนี้

สถานะ


Microsoft ยืนยันว่านี่เป็นปัญหาในผลิตภัณฑ์ของ Microsoft ซึ่งแสดงไว้ในส่วน "นำไปใช้กับ"

ข้อมูลอ้างอิง


VSTF DynamicsNAV SE: 248435
หมายเหตุ นี่คือบทความ "เผยแพร่เร็ว" ที่สร้างขึ้นโดยตรงจากภายใน Microsoft สนับสนุนองค์กร ข้อมูลในที่นี้ให้ไว้ตามสภาพ เพื่อตอบสนองกับปัญหาที่เกิดขึ้นใหม่ เป็นผลมาจากความเร็วในการทำให้พร้อมใช้งาน วัสดุอาจรวมถึงข้อผิดพลาดการพิมพ์ผิด และอาจแก้ไขได้ตลอดเวลาโดยไม่ต้องแจ้งให้ทราบ ดูข้อตกลงการใช้สำหรับข้อควรพิจารณาอื่น ๆ