|
แก้ไขครั้งสุดท้ายโดย puklit เมื่อ 2021-10-12 10:50
สวัสดีสมาชิกทุก ๆ ท่าน
วันนี้ผมจะมาขอนำเสนอการสร้างรายงานโดยการใช้คอนโทรล์ของค่าย DevExpress ดังนี้
- ChartControl
- PivotGrid
- GridControl, GridView
โดยลำดับของการเรียกแสดงรายงานตามเงือนไขผมได้เอามาจากระบบ SAP มาประยุกต์ใช้งานคือ
1. Multiselect
2. ALV grid control ของค่าย SAP ที่สามารถปรับแต่ง Layout และสามารถบันทึกรูปแบบ และโหลดมาใช้งานได้ โดยไม่ต้องเสียเวลามาจัด Layout ของ Grid ใหม่ทุกๆ ครั้งที่ต้องการข้อมูล
ทีนี้เรามาเข้าเนื้อนหาและลำดับการเรียกรายงานแบบมีเงือนไข (ผมใช้คอนโทรล์ของค่าย DevExpress ประยุกต์ใช้งาน) เริ่มจาก
1. ผู้ใช้งานระบุเงือนไขเข้ามา (แล้วกดปุ่มโหลดข้อมูล) ก่อนโหลดรายงานมาแสดง
สำหรับในการระบุเงื่อนไขนั้นผมได้สร้างฟอร์มกลางเข้ามารับค่าฟิลด์ของตารางและเงือนไขรวมถึงตัว Operator สำหรับฟิล์ดนั้น เข้ามาเก็บไว้ใน DataTable ที่สร้างขึ้นนมาดังนี้
โดยรูปแบบการระบุเงือนไขนี้ผมประยุกต์การใช้งานมาจาก Multiselection ของระบบ SAP สามารถระบุค่าและเลือกตัว Operator ของฟิลด์นั้นๆ ได้
ตัวอย่าง =, >, <, >=, <=, ไม่=, ไม่>, ไม่<, ไม่>=, ไม่<=, LIKE, ไม่LIKE, BETWEEN, ไม่BETWEEN เป็นต้น
ซึ่งผมได้เขียน เข้ามาเก็บไว้ใน DataTable ที่สร้างขึ้นนมา แล้วนำค่าเหล่านั้นมาสร้างในรูปแบบ Dynamic sql query อีกครั้ง
ตัวอย่างโค้ดที่เลือกค่าพารามิเตอร์ของแต่ละฟิลด์ เพื่อนำมาเก็บไว้ใน DataTable ที่สร้างไว้ก่อนนำไปสร้างคำสั่ง Dynamic sql query สำหรับโหลดข้อมูลจากฐานข้อมูล
- // เลือกเงื่อนไขสำหรับสร้าง Sql conditions
- private void BT_ButtonClick(object sender, DevExpress.XtraEditors.Controls.ButtonPressedEventArgs e)
- {
- ButtonEdit txt = sender as ButtonEdit;
- // กำหนดปุ่มที่เลือก ลบ / เลือก
- switch (e.Button.Index)
- {
- case 0: // เคลีย์ค่าเงื่อนไข
- dtSQLConditions.Rows.OfType<DataRow>().Where(r => r["FieldName"].ToString() == txt.Tag.ToString()).ToList().ForEach(r => r.Delete());
- dtSQLConditions.AcceptChanges();
- txt.Text = string.Empty;
- break;
- case 1: // เลือกเงือนไข
- FSQL_Condition frm = new FSQL_Condition();
- Prm_SQL prm = new Prm_SQL();
- switch (txt.Tag.ToString())
- {
- case "Current_WC": prm.SqlLine(frm, txt, dtSQLConditions, lbCurrent_WC.Text); break;
- case "R3_Workcenter": prm.SqlWorkCenter(frm, txt, dtSQLConditions, lbR3_Workcenter.Text); break;
- case "Process_Name": prm.SqlProcess(frm, txt, dtSQLConditions, lbProcess_Name.Text); break;
- case "SAPOpr_ID2": prm.SqlSAPOperation(frm, txt, dtSQLConditions, lbSAPOpr_ID2.Text); break;
- case "AsstLeader": prm.SqlAsstLeader(frm, txt, dtSQLConditions, lbAsstLeader.Text); break;
- case "Leader": prm.SqlLeader(frm, txt, dtSQLConditions, lbLeader.Text); break;
- case "Supervisor": prm.SqlSupervisor(frm, txt, dtSQLConditions, lbSupervisor.Text); break;
- case "Manager": prm.SqlManager(frm, txt, dtSQLConditions, lbManager.Text);break;
- case "Sec_Name": prm.SqlSection(frm, txt, dtSQLConditions, lbSec_Name.Text);break;
- case "Div_Name": prm.SqlDivision(frm, txt, dtSQLConditions, lbDiv_Name.Text); break;
- case "Dep_Name": prm.SqlDepartment(frm, txt, dtSQLConditions, lbDep_Name.Text); break;
- case "Plant_Code": prm.SqlPlantCode(frm, txt, dtSQLConditions, lbPlant_Code.Text); break;
- default: break;
- }
- // ตรวจสอบการระบุเงื่อนไข
- if (frm.IsExecute == true)
- {
- sql.SQLCreateConditions(dtSQLConditions, txt.Name.Replace("txt", string.Empty), txt); // สร้างเงื่อนไขใหม่ตามที่ผู้ใช้งานเลือก
- }
- break;
- default: break;
- }
- }
คัดลอกไปที่คลิปบอร์ด
2. เมื่อกดปุ่มโหลดรายงานผู้ใช้งานจะได้ข้อมูลมา 3 ส่วนดังนี้
2.1 Chart report
ตัวอย่างโค้ดที่ผมเขียนใช้งาน (ต้องขออภัยเป็นภาษา C#)
- private void Chart_Total()
- {
- ClsData cdt = new ClsData();
- string sqlstr = @"SELECT tbl.*
- INTO EmpDirect
- FROM
- (
- SELECT Direct_Flag, SUM(Totals) AS Totals
- FROM MAN_Employee_DataActived
- GROUP BY Direct_Flag, Current_WC, R3_Workcenter, Process_Name, SAPOpr_ID2, AsstLeader, Leader, Supervisor, Manager, Sec_Name, Div_Name, Dep_Name, Plant_Code
- {0}
- ) tbl
- SELECT Direct_Flag, SUM(Totals) AS Totals FROM EmpDirect GROUP BY Direct_Flag
- DROP TABLE EmpDirect";
- DataTable dt = new DataTable();
- cdt.Get_DataToDataTable(dt, string.Format(sqlstr, sql.SQLCommandStr(dtSQLConditions, ClsSql.Clause.HAVING, ClsSql.SQLOperator.AND)));
- ChartControl crt = chartTotal;
- crt.DataSource = dt;
- crt.Series[0].ArgumentDataMember = "Direct_Flag";
- crt.Series[0].ValueDataMembers.AddRange(new string[] { "Totals" });
คัดลอกไปที่คลิปบอร์ด
2.2 PivotGrid (ตัวนี้ผมจะเปิดเป็นรายงานในรูปแบบอิสระที่ผู้ใช้งานสามารถลากวางข้อมูลในรูปแบบที่ต้องการ แล้วสามารถบันทึกเป็นรูปแบบ และโหลดมาใช้งานเองได้)
ตัวอย่างโค้ด
- private void Show_PivotData()
- {
- ClsData cdt = new ClsData();
- string sqlstr = @"SELECT Gender, Direct_Flag, Emp_Type, Current_WC, Process_Name, SAPOpr_ID2, R3_Workcenter,
- Sec_Name, Div_Name, Dep_Name, AsstLeader, Leader, Supervisor, Manager, Plant_Code, Totals
- FROM View_MAN_Employee_DataActived
- {0}";
- DataTable rpt = new DataTable();
- cdt.Get_DataToDataTable(rpt, string.Format(sqlstr, sql.SQLCommandStr(dtSQLConditions, ClsSql.Clause.WHERE, ClsSql.SQLOperator.AND)));
- if (rpt.Rows.Count > 0) { IsContainData = true; } else { IsContainData = false; }
- pvgData.DataSource = rpt;
- SetPivotGrid();
- }
คัดลอกไปที่คลิปบอร์ด
2.3 GridView (Raw data)
ตัวอย่างโค้ด
- ClsGridview cgv = new ClsGridview();
- string sqlstr = @"SELECT Emp_ID, FullName, NickName, Gender, Direct_Flag, Emp_Type, Hiredate, Probation, Grade,
- Position_NameEN, WorkExp, Current_WC, Process_Name, SAPOpr_ID2, R3_Workcenter,
- Sec_Name, Div_Name, Dep_Name, AsstLeader, Leader, Supervisor, Manager, Plant_Code
- FROM View_MAN_Employee_DataActived
- {0}";
- cgv.Get_DataToGridview(string.Format(sqlstr, sql.SQLCommandStr(dtSQLConditions, ClsSql.Clause.WHERE, ClsSql.SQLOperator.AND)), "View_MAN_Employee_DataActived", gcData);
- SetGridRawDB();
คัดลอกไปที่คลิปบอร์ด
ซึ่งโค้ดตัวอย่างนี้จะถูกเรียกใช้งานจาก Class ที่ผมสร้างขึ้นมาอีกครั้งเพื่อลดการเขียนซ้ำและสะดวกในการพัฒนา
3. การสร้าง Option สำหรับบันทึกและโหลดรูปแบบ ที่เราสร้างเอาไว้ขึ้นมาใช้งาน
ไม่ว่าจะเป็น PivotGrid, GridView, BannedGrid ของค่าย DevExpress จะมีคุณสมบัติสามารถบันทึกและโหลดรูปแบบ ที่เรากำหนดเอาไว้มาใช้งานได้เหมือนกับ ALV GridControl ของระบบ SAP
ซึ่งค่าของรูปแบบนี้จะถูกจัดเก็บในรูปแบบ XML ซึ่งเราสามารถนำค่า XML ในี้จัดเก็บลงในฐานข้อมูลได้ ในที่นี้ผมได้เก็บลงใน SQL Server ดังนี้
ตัวอย่างฟอร์มที่ผมใช้ในการบันทึกรูปแบบของ PivotGrid, GridView, BannedGrid
ตัวอย่างโค้ด
- private void btSLayout_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
- {
- FLayout_Save frm = new FLayout_Save();
- // 2= PivodGrid, 3=GridView
- switch (TabPageIndex)
- {
- case 2: frm.LayoutParameters(pvgData, Grid.PivotGrid, this.Name); break;
- case 3: frm.LayoutParameters(gvData, Grid.GridView, this.Name); break;
- default: break;
- }
- frm.ShowDialog();
- }
คัดลอกไปที่คลิปบอร์ด
ตัวอย่างฟอร์มที่ผมใช้ในการโหลดรูปแบบของ PivotGrid, GridView, BannedGrid
ตัวอย่างโค้ด
- private void btCLayout_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
- {
- FLayout_Choose frm = new FLayout_Choose();
- // 2= PivodGrid, 3=GridView
- switch (TabPageIndex)
- {
- case 2: frm.LayoutParameters(pvgData, Grid.PivotGrid, this.Name); break;
- case 3: frm.LayoutParameters(gvData, Grid.GridView, this.Name); break;
- default: break;
- }
- frm.ShowDialog();
- }
คัดลอกไปที่คลิปบอร์ด
4. การนำข้อมูลจาก PivotGrid, GridView, BannedGrid เพื่อบันทึกไปยังไฟล์ต่างๆ เช่น .txt, .csv, .xls, .xlsx, .pdf เป็นต้น สามารถดูได้จากคู่มือของ DevExpress
สำหรับด้านล่างนี้ผมได้ออกแบบหน้าตาฟอร์มสำหรับนำออกข้อมูลของไฟล์ต่างๆ ต่างนี้
ตัวอย่างโค้ด
- private void btExportFile_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
- {
- FExportFile frm = new FExportFile();
- // 2= PivodGrid, 3=GridView
- switch (TabPageIndex)
- {
- case 2: frm.Export(pvgData); break;
- case 3: frm.Export(gvData); break;
- default: break;
- }
- frm.ShowDialog();
- }
คัดลอกไปที่คลิปบอร์ด
หวังว่าคงเป็นประโยชน์ต่อท่านสมาชิกหลายๆ ท่านเพื่อเป็นแนวทางในการสร้างรายงาน
หรือหากสมาชิกท่านใดมีแนวทางอื่นๆ ก็สามารถแลกเปลี่ยนประสบการณ์กันได้ครับ
ทั้งหมดนี้เป็นส่วนที่ผมประยุกต์มาสำหรับใช้งานในระบบจริง และตัวผมเองไม่่ได้เรียนมาสายนี้โดยตรง
อาศัยเริ่มต้นจาก Excel , Excel + VBA, VB จากเว็ปบอร์ดของอาจารย์ทองก้อน และต่อยอดมาจนถึงทุกวันนี้ครับ
ขอบคุณครับ
|
ขออภัย! โพสต์นี้มีไฟล์แนบหรือรูปภาพที่ไม่ได้รับอนุญาตให้คุณเข้าถึง
คุณจำเป็นต้อง ลงชื่อเข้าใช้ เพื่อดาวน์โหลดหรือดูไฟล์แนบนี้ คุณยังไม่มีบัญชีใช่ไหม? ลงทะเบียน
x
|