อาการ
การตั้งค่าในฟิลด์ "แสดง" ไม่ได้ถูกนำมาลงในบัญชีในภาพรวมการวิเคราะห์การขายและ exportation ของ Excel ใน Microsoft Dynamics NAV 2009 เฉพาะ "พิมพ์" ตัวเลือกที่จะพิจารณาตัวเลือกที่เลือกสำหรับเขตข้อมูลนี้หรือไม่ ทำตามขั้นตอนต่าง ๆ ในส่วนของการเปลี่ยนแปลงรหัสเพื่อแก้ไขปัญหานี้ ปัญหานี้เกิดขึ้นในผลิตภัณฑ์ต่อไปนี้:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 SP1
การแก้ปัญหา
ข้อมูลโปรแกรมแก้ไขด่วน
โปรแกรมแก้ไขด่วนจะพร้อมใช้งานได้ในขณะนี้จาก Microsoft อย่างไรก็ตาม มีเป้าหมายเพียงเพื่อการแก้ไขปัญหาที่อธิบายไว้ในบทความนี้ นำวิธีนี้ไปใช้กับระบบที่ประสบกับปัญหาที่เฉพาะเจาะจงเท่านั้น โปรแกรมแก้ไขด่วนนี้อาจได้รับการทดสอบเพิ่มเติม ดังนั้น ถ้าคุณจะไม่รุนแรงได้รับผลกระทบจากปัญหานี้ เราขอแนะนำให้ คุณรอ service pack ถัดไปของ Microsoft Dynamics NAV 2009 หรือเวอร์ชันถัดไป Microsoft Dynamics NAV ที่ประกอบด้วยโปรแกรมแก้ไขด่วนนี้
หมายเหตุ ในกรณีพิเศษ ค่าธรรมเนียมค่าใช้จ่ายสำหรับการสนับสนุนโทรศัพท์อาจถูกยกเลิกถ้า Technical Support Professional สำหรับ Microsoft Dynamics และผลิตภัณฑ์ที่เกี่ยวข้องตรวจพบว่าการปรับปรุงเฉพาะจะแก้ปัญหาของคุณ ค่าใช้จ่ายในการสนับสนุนตามปกติจะใช้กับคำถามและปัญหาในการสนับสนุนเพิ่มเติมซึ่งไม่สอดคล้องตามเกณฑ์สำหรับโปรแกรมปรับปรุงเฉพาะที่เกี่ยวข้อง
ข้อมูลการติดตั้ง
Microsoft ให้ตัวอย่างการเขียนโปรแกรมไว้สำหรับประกอบการอธิบายเท่านั้นโดยไม่มีการรับประกันไม่ว่าจะโดยชัดแจ้งหรือโดยนัย กรณีนี้รวมถึงแต่มิได้จำกัดเพียงแค่การการรับประกันโดยนัยเกี่ยวกับการจำหน่ายเป็นสินค้าหรือความเหมาะสำหรับวัตถุประสงค์เฉพาะ บทความนี้ตั้งสมมติฐานว่าคุณมีความคุ้นเคยกับภาษาการเขียนโปรแกรมที่กำลังแสดงและคุ้นเคยกับเครื่องมือที่ใช้ใน การสร้างและแก้จุดบกพร่องของขั้นตอนการดำเนินการ วิศวกรฝ่ายสนับสนุนของ Microsoft สามารถช่วยอธิบายเกี่ยวกับหน้าที่การใช้งานของกระบวนการเฉพาะ อย่างไรก็ตาม จะไม่แก้ไขตัวอย่างเหล่านี้เพื่อเพิ่มฟังก์ชัน หรือสร้างขั้นตอนเพื่อตอบสนองความต้องการเฉพาะของคุณ
หมายเหตุ ก่อนที่คุณติดตั้งโปรแกรมแก้ไขด่วนนี้ โปรดตรวจสอบว่า ผู้ใช้ไคลเอนต์ของ Microsoft Dynamics NAV ทั้งหมดเข้าสู่ระบบออกจากระบบ ข้อมูลนี้รวมถึงบริการ Microsoft Dynamics NAV แอพพลิเคชันเซิร์ฟเวอร์ (NAS) คุณควรไคลเอ็นต์เฉพาะผู้ใช้ที่เข้าสู่ระบบเมื่อคุณใช้โปรแกรมแก้ไขด่วนนี้
เมื่อต้องการใช้โปรแกรมแก้ไขด่วนนี้ คุณต้องมีสิทธิ์การใช้งานสำหรับนักพัฒนา
เราขอแนะนำว่า บัญชีผู้ใช้ ในหน้าต่างล็อกอินของ Windows หรือ ในหน้าต่างล็อกอินฐานข้อมูลสามารถกำหนดรหัสการเข้าถึงข้อมูล "ขั้นสูง" ถ้าบัญชีผู้ใช้ไม่สามารถกำหนดรหัสการบทบาท "SUPER" คุณต้องตรวจสอบว่า บัญชีผู้ใช้มีสิทธิ์ต่อไปนี้:
-
สิทธิ์การปรับเปลี่ยนสำหรับออปเจ็กต์ที่คุณจะสามารถเปลี่ยน
-
สิทธิ์ในการดำเนินการ สำหรับออบเจ็กต์5210 รหัสวัตถุของระบบและระบบ 9015 ID ของวัตถุ
วัตถุ
หมายเหตุ คุณไม่จำเป็นต้องมีสิทธิ์ไปยังร้านค้าข้อมูลยกเว้นว่าคุณจำเป็นต้องซ่อมแซมข้อมูล
การเปลี่ยนแปลงรหัส
หมายเหตุ เสมอทดสอบรหัสแก้ไขในสภาพแวดล้อมการควบคุมก่อนที่คุณนำไปใช้แก้ไขปัญหากับคอมพิวเตอร์ของคุณผลิต
เมื่อต้องการแก้ไขปัญหานี้ ให้ทำตามขั้นตอนเหล่านี้:
-
เปลี่ยนแปลงรหัสนี้ในคุณสมบัติในแบบฟอร์มเมตริกซ์การวิเคราะห์การขาย (9207) เป็นดังนี้:
รหัสที่อยู่ 1...LinksAllowed=No;
SourceTable=Table7114;
OnOpenForm=BEGIN
AnalysisColumn.SETRANGE("Analysis Area",AnalysisColumn."Analysis Area"::Sales);
AnalysisColumn.SETRANGE("Analysis Column Template",AnalysisColumn."Analysis Column Template");
AnalysisColumn.SETRANGE("Line No.",FirstLineNo,LastLineNo);
...รหัสแทนที่ 1
...LinksAllowed=No;
SourceTable=Table7114;
OnOpenForm=BEGIN
// Add the following line.
SETFILTER(Show,'<>%1',Show::No);
// End of the added line.
AnalysisColumn.SETRANGE("Analysis Area",AnalysisColumn."Analysis Area"::Sales);
AnalysisColumn.SETRANGE("Analysis Column Template",AnalysisColumn."Analysis Column Template");
AnalysisColumn.SETRANGE("Line No.",FirstLineNo,LastLineNo);
...รหัสที่มีอยู่ 2
...OnAfterGetRecord=BEGIN
i := 1;
IF AnalysisColumn.FIND('-') THEN BEGIN
REPEAT
IF i <= ARRAYLEN(MatrixData) THEN BEGIN
...รหัสแทนที่ 2
...OnAfterGetRecord=BEGIN
i := 1;
// Add the following line.
AnalysisColumn.SETFILTER(Show,'<>%1',AnalysisColumn.Show::Never);
// End of the added line.
IF AnalysisColumn.FIND('-') THEN BEGIN
REPEAT
IF i <= ARRAYLEN(MatrixData) THEN BEGIN
... -
เปลี่ยนแปลงรหัสนี้ในตัวควบคุมในแบบฟอร์มเมตริกซ์การวิเคราะห์การขาย (9207) เป็นดังนี้:
รหัสที่อยู่ 1...VertGlue=Both }
{ 2 ;TextBox ;0 ;0 ;1700 ;0 ;ParentControl=1;
InColumn=Yes;
// Delete the following line.
SourceExpr="Row Ref. No." }
// End of the deleted line.
{ 3 ;Label ;0 ;0 ;0 ;0 ;ParentControl=2;
InColumnHeading=Yes }
{ 4 ;TextBox ;0 ;0 ;2650 ;0 ;HorzGlue=Both;
...รหัสแทนที่ 1
...VertGlue=Both }
{ 2 ;TextBox ;0 ;0 ;1700 ;0 ;ParentControl=1;
InColumn=Yes;
// Add the following lines.
SourceExpr="Row Ref. No.";
OnFormat=BEGIN
CurrForm."Row Ref. No.".UPDATEFONTBOLD := Bold;
END;
}
// End of the added lines.
{ 3 ;Label ;0 ;0 ;0 ;0 ;ParentControl=2;
InColumnHeading=Yes }
{ 4 ;TextBox ;0 ;0 ;2650 ;0 ;HorzGlue=Both;
...รหัสที่มีอยู่ 2
... { 4 ;TextBox ;0 ;0 ;2650 ;0 ;HorzGlue=Both;
ParentControl=1;
InColumn=Yes;
// Delete the following line.
SourceExpr=Description }
// End of the deleted line.
{ 5 ;Label ;0 ;0 ;0 ;0 ;ParentControl=4;
InColumnHeading=Yes }
{ 9 ;TextBox ;3995 ;1100 ;1700 ;440 ;Name=Field1;
...รหัสแทนที่ 2
...{ 4 ;TextBox ;0 ;0 ;2650 ;0 ;HorzGlue=Both;
ParentControl=1;
InColumn=Yes;
// Add the following lines.
SourceExpr=Description;
OnFormat=BEGIN
CurrForm.Description.UPDATEFONTBOLD := Bold;
END;
}
// End of the added lines.
{ 5 ;Label ;0 ;0 ;0 ;0 ;ParentControl=4;
InColumnHeading=Yes }
{ 9 ;TextBox ;3995 ;1100 ;1700 ;440 ;Name=Field1;
... -
เปลี่ยนแปลงรหัสนี้ในฟังก์ชันFillMatrixColumnsหน้ารายงานการวิเคราะห์การขาย (7117) เป็นดังนี้:
รหัสที่มีอยู่...AnalysisColumn2.SETRANGE("Analysis Area",AnalysisColumn2."Analysis Area"::Sales);
AnalysisColumn2.SETRANGE("Analysis Column Template",CurrentColumnTemplate);
AnalysisColumn2.SETRANGE("Line No.",FirstLineNo,LastLineNo);
i := 1;
IF AnalysisColumn2.FIND('-') THEN
...รหัสแทน
...AnalysisColumn2.SETRANGE("Analysis Area",AnalysisColumn2."Analysis Area"::Sales);
AnalysisColumn2.SETRANGE("Analysis Column Template",CurrentColumnTemplate);
AnalysisColumn2.SETRANGE("Line No.",FirstLineNo,LastLineNo);
// Add the following line.
AnalysisColumn2.SETFILTER(Show,'<>%1',AnalysisColumn2.Show::Never);
// End of the added line.
i := 1;
IF AnalysisColumn2.FIND('-') THEN
... -
เปลี่ยนแปลงรหัสนี้ในคุณสมบัติในหน้าเมตริกซ์การวิเคราะห์ขาย (9207) เป็นดังนี้:
รหัสที่อยู่ 1...END;
OnOpenPage=BEGIN
AnalysisColumn.SETRANGE("Analysis Area",AnalysisColumn."Analysis Area"::Sales);
AnalysisColumn.SETRANGE("Analysis Column Template",AnalysisColumn."Analysis Column Template");
AnalysisColumn.SETRANGE("Line No.",FirstLineNo,LastLineNo);
...รหัสแทนที่ 1
...END;
OnOpenPage=BEGIN
// Add the following line.
SETFILTER(Show,'<>%1',Show::No);
// End of the added line.
AnalysisColumn.SETRANGE("Analysis Area",AnalysisColumn."Analysis Area"::Sales);
AnalysisColumn.SETRANGE("Analysis Column Template",AnalysisColumn."Analysis Column Template");
AnalysisColumn.SETRANGE("Line No.",FirstLineNo,LastLineNo);
...รหัสที่มีอยู่ 2
...OnAfterGetRecord=BEGIN
i := 1;
IF AnalysisColumn.FIND('-') THEN BEGIN
REPEAT
IF i <= ARRAYLEN(MatrixData) THEN BEGIN
...รหัสแทนที่ 2
...OnAfterGetRecord=BEGIN
i := 1;
// Add the following line.
AnalysisColumn.SETFILTER(Show,'<>%1',AnalysisColumn.Show::Never);
// End of the added line.
IF AnalysisColumn.FIND('-') THEN BEGIN
REPEAT
IF i <= ARRAYLEN(MatrixData) THEN BEGIN
... -
เปลี่ยนแปลงรหัสนี้ในตัวควบคุมในหน้าเมตริกซ์การวิเคราะห์ขาย (9207) เป็นดังนี้:
รหัสที่มีอยู่...GroupType=Repeater }
{ 2 ;2 ;Field ;
SourceExpr="Row Ref. No." }
{ 4 ;2 ;Field ;
SourceExpr=Description }
{ 9 ;2 ;Field ;
Name=Field1;
...รหัสแทน
...GroupType=Repeater }
{ 2 ;2 ;Field ;
SourceExpr="Row Ref. No.";
// Add the following line.
StyleExpr=RowRefNoEmphasize }
// End of the added line.
{ 4 ;2 ;Field ;
SourceExpr=Description;
// Add the following line.
StyleExpr=DescriptionEmphasize }
// End of the added line.
{ 9 ;2 ;Field ;
Name=Field1;
... -
เปลี่ยนแปลงรหัสนี้ในตัวแปรส่วนกลางในหน้าเมตริกซ์การวิเคราะห์ขาย (9207) เป็นดังนี้:
รหัสที่มีอยู่...Field30Visible@19010597 : Boolean INDATASET;
Field31Visible@19056564 : Boolean INDATASET;
Field32Visible@19017135 : Boolean INDATASET;
PROCEDURE Load@1(AnalysisColumn1@1000 : Record 7118;MatrixColumnCaptions1@1001 : ARRAY [32] OF Text[1024];ShowError1@1002 : 'None,Division by Zero,Period Error,Invalid Formula,Cyclic Formula,All';FirstLineNo1@1005 : Integer;LastLineNo1@1004 : Integer);
BEGIN
...รหัสแทน
...Field30Visible@19010597 : Boolean INDATASET;
Field31Visible@19056564 : Boolean INDATASET;
Field32Visible@19017135 : Boolean INDATASET;
// Add the following lines.
RowRefNoEmphasize@1170000002 : Boolean INDATASET;
DescriptionEmphasize@1170000001 : Boolean INDATASET;
// End of the added lines.
PROCEDURE Load@1(AnalysisColumn1@1000 : Record 7118;MatrixColumnCaptions1@1001 : ARRAY [32] OF Text[1024];ShowError1@1002 : 'None,Division by Zero,Period Error,Invalid Formula,Cyclic Formula,All';FirstLineNo1@1005 : Integer;LastLineNo1@1004 : Integer);
BEGIN
... -
เปลี่ยนแปลงรหัสนี้ในฟังก์ชัน t RowRefNoOnFormaในหน้าเมตริกซ์การวิเคราะห์ขาย (9207) เป็นดังนี้:
รหัสที่มีอยู่...Field32Visible := MatrixColumnCaptions[32] <> '';
END;
BEGIN
END.
}
...รหัสแทน
...Field32Visible := MatrixColumnCaptions[32] <> '';
END;
// Add the following lines.
LOCAL PROCEDURE RowRefNoOnFormat@19018750();
BEGIN
RowRefNoEmphasize := Bold;
END;
LOCAL PROCEDURE DescriptionOnFormat@19023855();
BEGIN
DescriptionEmphasize := Bold;
END;
// End of the added lines.
BEGIN
END.
}
... -
เปลี่ยนรหัสในรายงานรายงานการวิเคราะห์ (7112) เป็นดังนี้:
รหัสที่มีอยู่...DataItemTable=Table7114;
DataItemTableView=SORTING(Analysis Area,Analysis Line Template Name,Line No.);
OnPreDataItem=BEGIN
SETFILTER("Date Filter",DateFilter);
SETFILTER("Item Budget Filter",ItemBudgetFilter);
SETFILTER("Location Filter",LocationFilter);
...รหัสแทน
...DataItemTable=Table7114;
DataItemTableView=SORTING(Analysis Area,Analysis Line Template Name,Line No.);
OnPreDataItem=BEGIN
// Add the following line.
SETFILTER(Show,'<>%1',Show::No);
// End of the added line.
SETFILTER("Date Filter",DateFilter);
SETFILTER("Item Budget Filter",ItemBudgetFilter);
SETFILTER("Location Filter",LocationFilter);
... -
เปลี่ยนรหัสในการวิเคราะห์พนักงานส่งออกเป็นรายงาน Excel (7113) เป็นดังนี้:
รหัสที่มีอยู่...END;
RowNo := RowNo + 1;
IF AnalysisLine.FIND('-') THEN BEGIN
IF ColumnLayout.FIND('-') THEN BEGIN
RowNo := RowNo + 1;
...รหัสแทน
... END;
RowNo := RowNo + 1;
// Add the following line.
AnalysisLine.SETFILTER(Show,'<>%1',AnalysisLine.Show::No);
// End of the added line.
IF AnalysisLine.FIND('-') THEN BEGIN
IF ColumnLayout.FIND('-') THEN BEGIN
RowNo := RowNo + 1;
... -
เปลี่ยนรหัสในฟังก์ชัน SetOptions ในการวิเคราะห์พนักงานส่งออกเป็นรายงาน Excel (7113) เป็นดังนี้:
รหัสที่มีอยู่...AnalysisLine.SETFILTER("Analysis Line Template Name",NewAnalysisTemplateName);
ColumnLayout.SETRANGE("Analysis Area",AnalysisLine2."Analysis Area");
ColumnLayout.SETRANGE("Analysis Column Template",ColumnLayoutName2);
END;
PROCEDURE UpdateRequestForm@1();
...รหัสแทน
...AnalysisLine.SETFILTER("Analysis Line Template Name",NewAnalysisTemplateName);
ColumnLayout.SETRANGE("Analysis Area",AnalysisLine2."Analysis Area");
ColumnLayout.SETRANGE("Analysis Column Template",ColumnLayoutName2);
// Add the following line.
ColumnLayout.SETFILTER(Show,'<>%1',ColumnLayout.Show::Never);
// End of the added line.
END;
PROCEDURE UpdateRequestForm@1();
...
ข้อกำหนดเบื้องต้น
คุณต้องมีหนึ่งผลิตภัณฑ์ต่อไปนี้ติดตั้งอยู่เพื่อใช้โปรแกรมแก้ไขด่วนนี้:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 SP1
ข้อมูลการเอาออก
คุณไม่สามารถเอาโปรแกรมแก้ไขด่วนนี้
สถานะ
Microsoft ยืนยันว่านี่เป็นปัญหาในผลิตภัณฑ์ของ Microsoft ซึ่งแสดงไว้ในส่วน "นำไปใช้กับ"
ดูบทความแสดงการตั้งค่าเขตข้อมูลจะถูกละเว้นในบรรทัดการจัดกำหนดการบัญชีและ exportation ของ Excel ใน Microsoft Dynamics NAV 2009สำหรับข้อมูลเพิ่มเติม
หมายเหตุ นี่คือบทความ "เผยแพร่เร็ว" ที่สร้างขึ้นโดยตรงจากภายใน Microsoft สนับสนุนองค์กร ข้อมูลในที่นี้ให้ไว้ตามสภาพ เพื่อตอบสนองกับปัญหาที่เกิดขึ้นใหม่ เป็นผลมาจากความเร็วในการทำให้พร้อมใช้งาน วัสดุอาจรวมถึงข้อผิดพลาดการพิมพ์ผิด และอาจแก้ไขได้ตลอดเวลาโดยไม่ต้องแจ้งให้ทราบ ดูข้อตกลงการใช้สำหรับข้อควรพิจารณาอื่น ๆ