นำไปใช้กับ
Dynamics NAV 2009

อาการ

การตั้งค่าในฟิลด์ "แสดง" ไม่ได้ถูกนำมาลงในบัญชีในภาพรวมการวิเคราะห์การขายและ 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 ของวัตถุวัตถุ

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

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

หมายเหตุ เสมอทดสอบรหัสแก้ไขในสภาพแวดล้อมการควบคุมก่อนที่คุณนำไปใช้แก้ไขปัญหากับคอมพิวเตอร์ของคุณผลิตเมื่อต้องการแก้ไขปัญหานี้ ให้ทำตามขั้นตอนเหล่านี้:

  1. เปลี่ยนแปลงรหัสนี้ในคุณสมบัติในแบบฟอร์มเมตริกซ์การวิเคราะห์การขาย (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...
  2. เปลี่ยนแปลงรหัสนี้ในตัวควบคุมในแบบฟอร์มเมตริกซ์การวิเคราะห์การขาย (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=BEGINCurrForm."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=BEGINCurrForm.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;...
  3. เปลี่ยนแปลงรหัสนี้ในฟังก์ชัน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...
  4. เปลี่ยนแปลงรหัสนี้ในคุณสมบัติในหน้าเมตริกซ์การวิเคราะห์ขาย (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...
  5. เปลี่ยนแปลงรหัสนี้ในตัวควบคุมในหน้าเมตริกซ์การวิเคราะห์ขาย (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;...
  6. เปลี่ยนแปลงรหัสนี้ในตัวแปรส่วนกลางในหน้าเมตริกซ์การวิเคราะห์ขาย (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...
  7. เปลี่ยนแปลงรหัสนี้ในฟังก์ชัน t RowRefNoOnFormaในหน้าเมตริกซ์การวิเคราะห์ขาย (9207) เป็นดังนี้:รหัสที่มีอยู่

    ...Field32Visible := MatrixColumnCaptions[32] <> '';    END;    BEGIN    END.  }...

    รหัสแทน

    ...Field32Visible := MatrixColumnCaptions[32] <> '';    END;// Add the following lines.LOCAL PROCEDURE RowRefNoOnFormat@19018750();BEGINRowRefNoEmphasize := Bold;END;LOCAL PROCEDURE DescriptionOnFormat@19023855();BEGINDescriptionEmphasize := Bold;END;// End of the added lines.    BEGIN    END.  }...
  8. เปลี่ยนรหัสในรายงานรายงานการวิเคราะห์ (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);...
  9. เปลี่ยนรหัสในการวิเคราะห์พนักงานส่งออกเป็นรายงาน 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;...
  10. เปลี่ยนรหัสในฟังก์ชัน 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 สนับสนุนองค์กร ข้อมูลในที่นี้ให้ไว้ตามสภาพ เพื่อตอบสนองกับปัญหาที่เกิดขึ้นใหม่ เป็นผลมาจากความเร็วในการทำให้พร้อมใช้งาน วัสดุอาจรวมถึงข้อผิดพลาดการพิมพ์ผิด และอาจแก้ไขได้ตลอดเวลาโดยไม่ต้องแจ้งให้ทราบ ดูข้อตกลงการใช้สำหรับข้อควรพิจารณาอื่น ๆ

ต้องการความช่วยเหลือเพิ่มเติมหรือไม่

ต้องการตัวเลือกเพิ่มเติมหรือไม่

สํารวจสิทธิประโยชน์ของการสมัครใช้งาน เรียกดูหลักสูตรการฝึกอบรม เรียนรู้วิธีการรักษาความปลอดภัยอุปกรณ์ของคุณ และอื่นๆ