【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit2-Form2用户电量查询显示界面

简介: 【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit2-Form2用户电量查询显示界面

下面介绍Unit2用户电量查询显示界面的实现。

此界面并没有使用什么独特的控件,其中使用了多标签PageControl,数据显示DBGrid,图标Chart控件。


其中DBGird控件直接与Form1中的DataSource相连,由数据库读出的数据直接使用add语句,在Chart控件中进行显示。

1.数据的查询

操作数据库自然使用SQL语句,输入带变量的SQL语句,可以使用Form1中Timer4的输入方法(见Unit1技术细节4.Timer4),这里举例一种直接使用“+”来产生控制语句字符串的方法。

  u_Date := datetostr(teDateTimePicker1.DateTime);//获得用户选择的时间
  u_Year:=leftStr(u_Date,4);//取年
  u_Month:=copy(u_Date,6,2);//取月
  u_Day:=copy(u_Date,9,2);//取日
//  tememo2.Text := u_Date;
//  tememo1.Text := u_Year+u_Month+u_Day;
  form1.IBdatabase1.Connected:=true;
  form1.IBquery1.Close;
  form1.ibquery1.SQL.Clear;
  case f2dlCombo.ItemIndex of
    0:form1.ibquery1.SQL.Add('select * from BH0 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);//查询当年月日的数据
    1:form1.ibquery1.SQL.Add('select * from BH1 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    2:form1.ibquery1.SQL.Add('select * from BH2 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    3:form1.ibquery1.SQL.Add('select * from BH3 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    4:form1.ibquery1.SQL.Add('select * from BH4 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    5:form1.ibquery1.SQL.Add('select * from BH5 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    6:form1.ibquery1.SQL.Add('select * from BH6 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    7:form1.ibquery1.SQL.Add('select * from BH7 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    8:form1.ibquery1.SQL.Add('select * from BH8 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
    9:form1.ibquery1.SQL.Add('select * from BH9 where u_day='+ u_Day +
                        'and u_month=' + u_Month + 'and u_year=' + u_Year);
  end;
  form1.ibquery1.Open;  //这时值已经放到IBQuery中了

其中可以观察到  u_Date,u_Year,u_Month,u_Day : string;即均为字符型数据,传输的SQL数据也为字符串型,因此,直接将 u_Date,u_Year,u_Month,u_Day加入到SQL语句中是符合类型的。因此使用语句('select * from BH0 where u_day='+ u_Day + 'and u_month=' + u_Month + 'and u_year=' + u_Year) 可以找出指定年月日的所有数据。


2.数据的显示

对于数据的显示,使用series1的add命令,将得到的数据add到表中,之后进行显示即可。


下面展示的是使用最笨的方法将数据读出:


定义一个数组 adayhour来存放24小时的数据,如  adayhour : array [1..24] of real;

  adayhour[1] := form1.ibquery1.FieldByName('H1').AsFloat ;//按字段名取出数据,分别放到数组中
  adayhour[2] := form1.ibquery1.FieldByName('H2').AsFloat ;//因为数据类型不一样,所以要加.asfloat
  adayhour[3] := form1.ibquery1.FieldByName('H3').AsFloat ;
  adayhour[4] := form1.ibquery1.FieldByName('H4').AsFloat ;
  adayhour[5] := form1.ibquery1.FieldByName('H5').AsFloat ;
  adayhour[6] := form1.ibquery1.FieldByName('H6').AsFloat ;
  adayhour[7] := form1.ibquery1.FieldByName('H7').AsFloat ;
  adayhour[8] := form1.ibquery1.FieldByName('H8').AsFloat ;
  adayhour[9] := form1.ibquery1.FieldByName('H9').AsFloat ;
  adayhour[10] := form1.ibquery1.FieldByName('H10').AsFloat ;
  adayhour[11] := form1.ibquery1.FieldByName('H11').AsFloat ;
  adayhour[12] := form1.ibquery1.FieldByName('H12').AsFloat ;
  adayhour[13] := form1.ibquery1.FieldByName('H13').AsFloat ;
  adayhour[14] := form1.ibquery1.FieldByName('H14').AsFloat ;
  adayhour[15] := form1.ibquery1.FieldByName('H15').AsFloat ;
  adayhour[16] := form1.ibquery1.FieldByName('H16').AsFloat ;
  adayhour[17] := form1.ibquery1.FieldByName('H17').AsFloat ;
  adayhour[18] := form1.ibquery1.FieldByName('H18').AsFloat ;
  adayhour[19] := form1.ibquery1.FieldByName('H19').AsFloat ;
  adayhour[20] := form1.ibquery1.FieldByName('H20').AsFloat ;
  adayhour[21] := form1.ibquery1.FieldByName('H21').AsFloat ;
  adayhour[22] := form1.ibquery1.FieldByName('H22').AsFloat ;
  adayhour[23] := form1.ibquery1.FieldByName('H23').AsFloat ;
  adayhour[24] := form1.ibquery1.FieldByName('H24').AsFloat ;

使用 ibquery1.FieldByName('?').AsFloat 语句即可以float类型将字段名为“?”的数据取出,之后使用add命令将其加入到series1中。

  series1.Clear;//要先清空series,要不他会总add
  with series1 do
  begin
  add(0);//占了x=0,让显示看起来好看
    for i := 1 to 24 do
      add(adayhour[i]);
  end;
相关文章
|
人工智能 机器人 Go
无需安装SD,QuickQR.Art艺术二维码保姆级教程!(营销新风口)
无需安装SD,QuickQR.Art艺术二维码保姆级教程!(营销新风口)
309 0
|
3月前
|
传感器 C# 监控
硬件交互新体验:WPF与传感器的完美结合——从初始化串行端口到读取温度数据,一步步教你打造实时监控的智能应用
【8月更文挑战第31天】本文通过详细教程,指导Windows Presentation Foundation (WPF) 开发者如何读取并处理温度传感器数据,增强应用程序的功能性和用户体验。首先,通过`.NET Framework`的`Serial Port`类实现与传感器的串行通信;接着,创建WPF界面显示实时数据;最后,提供示例代码说明如何初始化串行端口及读取数据。无论哪种传感器,只要支持串行通信,均可采用类似方法集成到WPF应用中。适合希望掌握硬件交互技术的WPF开发者参考。
66 0
|
5月前
|
存储 Python
基于树莓派的流星雨监测系统(RMS)的进一步改造(1)
本文介绍了如何搭建和改造流星雨监测系统,主要涉及两个步骤。首先,文章提供了访问[此处链接](https://blog.csdn.net/delacroix_xu/article/details/119813807)来了解如何搭建系统。接着,针对系统输出的.bin文件格式,作者改造了FRbinViewer.py脚本,增加了输出MP4和GIF格式的功能。改造后的脚本可以根据用户选择将检测到的流星雨帧保存为.gif或.mp4格式,并提供了相应的参数设置。此外,文章还包含了代码示例以展示如何实现这一功能。
2023年电赛---运动目标控制与自动追踪系统(E题)OpenART mini的代码移植到OpenMV
2023年电赛---运动目标控制与自动追踪系统(E题)OpenART mini的代码移植到OpenMV
210 0
|
6月前
|
存储
医院PACS系统全套源码 强大的三维重建功能
对非DICOM影像,如超声、病理、心电图等进行了集成,做到了可以同时处理DICOM标准图像和非DICOM图像。
57 1
|
编解码 计算机视觉 Python
2023年电赛---运动目标控制与自动追踪系统(E题)关于网友的问题回复
2023年电赛---运动目标控制与自动追踪系统(E题)关于网友的问题回复
416 0
|
监控
【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit3-Form3用户负载类型查询界面
【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit3-Form3用户负载类型查询界面
|
监控 数据库
【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit4-Form4系统设置界面
【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit4-Form4系统设置界面
113 0
|
存储 SQL 监控
【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit1-Form1主界面
【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之Unit1-Form1主界面
127 0
|
存储 BI 数据安全/隐私保护
PACS系统源码 大型医院PACS/RIS源码 支持专业三维影像后处理功能,演示文档齐全
PACS系统可实现检查预约、病人信息登记、计算机阅片、电子报告书写、胶片打印、报表统计、数据备份等一系列满足影像科室日常工作的功能,并且由于影像数字化存储,用户可利用影像处理与测量技术辅助诊断、方便快捷地查找资料或利用网络将资料传输至临床科室,还可与医院HIS、LIS无缝连接。集成专业三维影像后处理功能:三维多平面重建、三维容积重建、三维表面重建、三维虚拟内窥镜、最大/小密度投影、心脏动脉钙化分析等。
156 0
PACS系统源码 大型医院PACS/RIS源码 支持专业三维影像后处理功能,演示文档齐全