DeviceStatusInfo.cs 4.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. using System;
  2. using DevExpress.XtraEditors;
  3. using UAS_PLCDataReader.DataOperate;
  4. using UAS_PLCDataReader.Entity;
  5. using System.Data;
  6. using System.Text;
  7. using UAS_PLCDataReader.PublicMethod;
  8. using System.Windows.Forms;
  9. using System.Collections.Generic;
  10. namespace UAS_PLCDataReader.Device.Infomation
  11. {
  12. public partial class DeviceStatusInfo : XtraForm
  13. {
  14. DataHelper dh = SystemInf.dh;
  15. StringBuilder sql = new StringBuilder();
  16. string de_code = "";
  17. public DeviceStatusInfo()
  18. {
  19. InitializeComponent();
  20. }
  21. public DeviceStatusInfo(string DevcieCode)
  22. {
  23. InitializeComponent();
  24. de_code = DevcieCode;
  25. Text = DevcieCode;
  26. }
  27. private void DeviceStatusInfo_Load(object sender, EventArgs e)
  28. {
  29. //查询设备基础信息
  30. sql.Clear();
  31. sql.Append("select de_linecode,de_wccode,de_name,de_address,de_sourcecode,sc_name from device ");
  32. sql.Append("left join source on sc_code=de_sourcecode where de_code='" + de_code + "' and rownum<50 ");
  33. DataTable dt = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  34. if (dt.Rows.Count > 0)
  35. {
  36. BaseUtil.SetFormValue(Controls, dt);
  37. }
  38. //查询设备参数信息
  39. sql.Clear();
  40. sql.Append("select dr_updatedate,case when dc_type='INQTY' then '投入' when dc_type='INGORE' then '忽略' when dc_type='OUTQTY' then '产出' when dc_type='NGQTY' then '不良'");
  41. sql.Append("when dc_type='PARAM1' then de_item1 when dc_type='PARAM2' then de_item2 when dc_type='PARAM3' then de_item3 ");
  42. sql.Append("when dc_type='PARAM4' then de_item4 when dc_type='PARAM5' then de_item5 when dc_type='PARAM6' then de_item6 ");
  43. sql.Append("when dc_type='PARAM7' then de_item7 when dc_type='PARAM8' then de_item8 when dc_type='PARAM9' then de_item9 ");
  44. sql.Append("when dc_type='PARAM10' then de_item10 end dc_name,case when dc_type='INQTY' when dc_type='INGORE' then '忽略' then dr_qty when dc_type='OUTQTY' then dr_okqty when dc_type='NGQTY' then dr_ngqty ");
  45. sql.Append("when dc_type='TEMPERATURE' then dr_TEMPERATURE when dc_type='PARAM1' then dr_value1 when dc_type='PARAM2' then dr_value2 ");
  46. sql.Append("when dc_type='PARAM3' then dr_value3 when dc_type='PARAM4' then dr_value4 when dc_type='PARAM5' then dr_value5 ");
  47. sql.Append("when dc_type='PARAM6' then dr_value6 when dc_type='PARAM7' then dr_value7 when dc_type='PARAM8' then dr_value8 ");
  48. sql.Append("when dc_type='PARAM9' then dr_value9 when dc_type='PARAM10' then dr_value10 end data from DEVICEPOLLINGCONFIG ");
  49. sql.Append("left join devicecommand on dpc_dccode = dc_code left join DEVICERUNSTATUS on dpc_decode = dr_decode left join device on dpc_decode=de_code where dpc_decode='"+ de_code + "' order by dc_dataindex");
  50. GridDeivceStatusInfo.DataSource = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  51. GridViewDeviceStatusInfo.BestFitColumns();
  52. sql.Clear();
  53. //查询设备运行日志
  54. sql.Append("select * from DEVICERUNRECORD where drr_decode='" + de_code + "' and rownum<50 ");
  55. GridDeviceRunLog.DataSource = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  56. GridViewDeviceRunLog.BestFitColumns();
  57. sql.Clear();
  58. sql.Append("select '接收'||nvl(dpg_receivedatasize,0)||'字节' dpg_receivedatasize,'发送'||nvl(dpg_senddatasize,0)||'字节' dpg_senddatasize");
  59. sql.Append(",dpg_onlinetime,dpg_offlinetime,'IP:'||dnc_ip dnc_ip,'端口:'|| dnc_port||',间隔'||dpg_interval||'S' dnc_port,");
  60. sql.Append("round(to_number(sysdate-DPG_STARTTIME )*1440) dpg_runtime from devicepollinglog left join DEVICENETCONFIG on dnc_decode=dpg_decode ");
  61. sql.Append("where dpg_id=(select max(dpg_id) from devicepollinglog where dpg_decode='" + de_code + "')");
  62. dt = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  63. if (dt.Rows.Count > 0)
  64. {
  65. BaseUtil.SetFormValue(this.Controls, dt);
  66. string TimeSpan = dt.Rows[0]["dpg_runtime"].ToString();
  67. dpg_runtime.Text = BaseUtil.MinutesToDayTime(int.Parse(TimeSpan == "" ? "0" : TimeSpan));
  68. }
  69. }
  70. private void DeviceStatusInfo_KeyDown(object sender, KeyEventArgs e)
  71. {
  72. if (e.KeyCode == Keys.Escape)
  73. Close();
  74. }
  75. }
  76. }