【乌拉喵.教程】“多负载识别监控平台(上位机)”技术细节 之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;
相关文章
|
数据采集 网络协议 定位技术
Socks5代理IP可以运用到哪些应用场景?
Socks5代理与HTTP代理对比,Socks5支持多种协议,提供更强认证,适合P2P和UDP,适用于匿名上网、突破网络限制、低延迟游戏、P2P文件共享、SEO和网络爬虫。其多功能性、安全性和广泛支持使其在多个场景中优于HTTP代理。随着技术发展,Socks5代理的应用前景广阔。
|
2月前
|
监控 算法 Java
深入理解JVM《G1垃圾收集器:面向局部收集与停顿模型的里程碑》
G1收集器是JDK 9+默认的高性能垃圾回收器,采用Region分区模型,实现可预测停顿时间。它通过RSet跟踪跨区引用,结合SATB算法确保并发标记准确性,兼顾低延迟与高吞吐,适用于大内存多核场景。
|
2月前
|
人工智能 自然语言处理 搜索推荐
拔俗AI政务智能体:让政务服务更聪明、更贴心
AI政务智能体是基于人工智能的“数字公务员”,可24小时在线解答政策疑问、智能引导办事、自动填表申报,让政务服务更高效便捷。它整合政策数据,实现“一问即答、一办到底”,提升群众满意度,助力政府治理现代化,推动“数据多跑路,群众少跑腿”真正落地。
|
2月前
|
人工智能 IDE 开发工具
拔俗人工智能辅助评审系统:如何用技术为“把关”提效
人工智能辅助评审系统融合大模型、提示工程与业务流程,实现上下文深度理解、场景化精准引导与无缝集成。通过自动化基础审查,释放专家精力聚焦核心决策,提升评审效率与质量,构建人机协同新范式。(239字)
|
7月前
|
存储 人工智能 安全
赋能数字化转型的创新引擎
阿里云是全球领先的云计算与人工智能科技公司,其强大的技术实力和丰富的解决方案正深刻影响企业运营与竞争力。依托坚实的云计算基础设施,阿里云提供弹性计算、存储与网络服务,满足多样化需求。在AI与大数据领域,机器学习平台PAI及MaxCompute助力智能决策与创新应用。同时,阿里云构建全方位安全防护体系,保障数据隐私,并通过活跃的开发者社区与生态合作推动行业进步。未来,阿里云将持续加大研发投入,优化云原生技术,深化AI与大数据研究,引领数字化转型潮流,共创美好未来。
赋能数字化转型的创新引擎
|
10月前
|
人工智能 数据挖掘 测试技术
大模型代肝,自动刷《崩铁》升级材料,Claude操纵计算机还能这么用!
Claude 3.5 Computer Use是首个提供公共测试的具备图形用户界面(GUI)操作能力的前沿AI模型,标志着GUI自动化领域的重要突破。它通过API调用实现端到端解决方案,能根据用户指令和视觉GUI状态生成操作,无需外部知识辅助。研究展示了其在网页搜索、工作流和生产力软件等任务中的卓越能力,并揭示了滚动导航等局限性。未来有望进一步优化并拓展应用领域。论文链接:https://arxiv.org/pdf/2411.10323。
355 38
|
9月前
|
机器学习/深度学习 人工智能 运维
《深度剖析:网络拓扑结构如何重塑人工智能数据传输效率》
在网络拓扑结构中,星形、总线、环形和网状拓扑各有优劣。星形结构简单易管理但存在单点故障风险;总线结构成本低但易受干扰;环形结构实时性好但可靠性低;网状结构可靠性高但布线复杂。这些拓扑结构直接影响数据传输的延迟、带宽利用和容错能力,进而影响人工智能系统的性能。随着AI对数据传输要求的提高,混合拓扑及SDN等新技术逐渐兴起,推动网络架构不断创新,优化AI数据传输效率,助力智能时代的进一步发展。
379 10
|
自然语言处理
学生党打工人救星,GPT一句话生成精美PPT
学生党打工人救星,GPT一句话生成精美PPT
681 1
|
机器学习/深度学习 自然语言处理
【AIGC】探索大语言模型中的词元化技术机器应用实例
【AIGC】探索大语言模型中的词元化技术机器应用实例
253 0
|
设计模式 缓存 Java
Java新时代:微服务架构下的性能优化实践
【2月更文挑战第12天】 在当今快速发展的软件工程领域,微服务架构因其灵活性和可扩展性而成为主流。随着应用程序变得日益复杂,性能优化成为了开发者不可回避的挑战。本文将探讨在Java环境下,利用微服务架构进行性能优化的策略和实践。我们将从微服务的基本概念出发,深入分析如何通过设计模式、数据库优化、缓存机制以及并发处理等手段,有效提升Java应用的性能。此外,本文还将分享一些实际案例,以帮助读者更好地理解和应用这些优化技术。