台达PLC配合组态王实现工厂产量监控查询系统.doc

上传人:工**** 文档编号:543822020 上传时间:2024-02-29 格式:DOC 页数:17 大小:728.01KB
返回 下载 相关 举报
台达PLC配合组态王实现工厂产量监控查询系统.doc_第1页
第1页 / 共17页
台达PLC配合组态王实现工厂产量监控查询系统.doc_第2页
第2页 / 共17页
台达PLC配合组态王实现工厂产量监控查询系统.doc_第3页
第3页 / 共17页
台达PLC配合组态王实现工厂产量监控查询系统.doc_第4页
第4页 / 共17页
台达PLC配合组态王实现工厂产量监控查询系统.doc_第5页
第5页 / 共17页
点击查看更多>>
资源描述

《台达PLC配合组态王实现工厂产量监控查询系统.doc》由会员分享,可在线阅读,更多相关《台达PLC配合组态王实现工厂产量监控查询系统.doc(17页珍藏版)》请在金锄头文库上搜索。

1、台达PLC配合组态王实现工厂产量监控查询系统1引言 产量监控查询系统系统对整个工厂所有生产线进行实时监控,对每一条生产线的产量进行实时的存储,存储的数据通过组态王连接PLC,将PLC中掉电保持区的数据读到组态王自定义的相应变量当中,每分钟通过标准的SQL语言对数据进行存储(每分钟向SQLSERVER数据库中存储26条数据,即26条生产线的当前产量)。用户可以通过:日期、时间、时间段、车间、生产线对任何车间、任何生产线进行产量的查询;能够对任何车间、任何生产线进行月产量的统计。同时在查询出满足条件的记录后,将结果通过报表的组态显示在相应的表格当中,可以对该结果进行存储和打印。 2系统设计 2.1

2、系统框图(图1) 图1产量监控查询系统框图 2.2设备选型设计 3系统分析 3.1功能要求 可以任意查询一车间、二车间任何生产线(共26条生产线)任何时段的产量。具体明 细如下: (1)每条生产线产量的数据至少能够保存四个月的储存期,以便对历史数据进行查询。 (2)要求能够查询每条生产线任意每月、任意每天、任意每小时、任意每分钟的产量。 (3)要求能够对任意每条生产线在任意时段的产量进行查询。 (4)查询出来的任何结果要以特定的格式在报表中进行组态,同时将结果打印。 (5)各生产线任意每月产量、任意每天产量、任意每小时产量、任意每分钟产量可以在电脑上用柱状图、实时趋势曲线的形式表现出来 3.2

3、查询方式 (1)能够按照日期进行查询(格式:Year/Month/Day) (2)能够按照时间进行查询(格式:Hour/Minute/Second) (3)能够按照生产线进行查询(一车间:1-1、1-2;2-1,2-2;3-1,3-2;4-1,4-2; 5-1,5-2;6-1,6-2;7-1,7-2;8-1,8-2二车间:1-1,1-2;2-1,2-2;3-1,3-2;4-1,4-2,4-3,4-4) (4)能够按照任意时间段进行查询(格式:Year/Month/DayHour/Minute/SecondToYear/Month/Day/Hour/Minute/Second) (5)能够按照班

4、次进行查询(格式:早班,中班,晚班)早班:7:3015:30 中班:15:3023:30晚班:23:307:30 (6)能够查询任意每月任意车间、任意生产线的产量 (7)能够运用的各种不同的排列组合进行复杂的查询 4难点及实现方法 4.1海量数据管理 两个车间共26条生产线,每分钟要有26条记录生成,每分钟向数据库插入26条记录。 该系统全天24小时工作,不允许停。所以一天的数据量为37440条记录。每月的数据量为1160640条记录。如果要存储四个月,则数据量为4642260条记录。数据量是相当庞大的。硬盘的数据存储接近2-3G,不仅会造成在查询时,系统资源严重被占用,同时普通的数据库如AC

5、CESS的表格没有能力管理如此庞大的数据系统。ACCESS在管理如此庞大的数据时,不仅系统会造成不稳定,同时会出现不可预料的情形。所以只能寻找能够管理大型数据系统的数据库,因此可以选择SQLSERVER或Oracle。 4.2基于WindowsXP创建SQL服务器的新数据源 组态王支持对标准的数据库进行数据的插入、选择、删除等基本的操作。同时支持标准的SQL语言。灵活的运用组态王提供的SQL函数使组态王通过ODBC(开放性的数据源)配合标准的SQL语言对数据库进行各种简单和复杂的操作。 在Win2000/Winnt/Winxp等操作系统下,必须正确的进行设置:从控制面板中 双击性能和维护,如图

6、3所示。以WindowsXP为例说明。 第一步:在控制面板下选择管理工具ODBC数据源,双击图标出现图2界面。 图2ODBC数据源管理器界面 第二步:在用户DSN选项卡片上,单击添加按钮,出现创建新数据源对话框,选择SQLServer(图3)。 图3创建新数据源 第三步:单击第二步的完成按钮,出现创建到SQLServer的新数据源。如图4所示。 图4创建SQL服务器的新数据源(1)输入数据源名称、数据源描述和SQLServer所在的服务器名称或者IP地址。服务器名称可以是SQLServer所在的机器名称,也可以是IP地址。单击下一步按钮。 第四步:选择登录SQLServer时的身份验证方式。并

7、输入登录SQLServer时所用到的用户名和密码。如图5所示。图5创建SQL服务器的新数据源(2)这里的用户名和密码是在SQLServer中建立的。在SQLServer数据库中选择安全性登录,新建用户,如图6所示。 图6创建SQL服务器的新数据源(3)第五步 一定要选择选项,否则默认数据库是master。然后选择您想要连接的数据库。其余的按 默认设置,如图7所示。然后单击下一步按钮。图7创建SQL服务器的新数据源(4)第六步:按默认设置,单击完成按钮(图8)。 图8创建SQL服务器的新数据源(5)第七步:图9给出了数据库连接的摘要信息,如果想测试一下是否能够连接到数据库,可以单击“测试数据源”

8、按钮,会出现测试结果。 图9创建SQL服务器的新数据源(6)单击确定完成连接。接下来的工作就是在组态王王建立记录体、表格模板。其中连接数据库的时候,一定要输入和刚才数据源名称一致的DSN。如dsn=wuhandsn. 4.3表格名称创新 即使使用大型的数据库,SQLServer或Oracle,由于每天的数据量多达37440条记录, 如果将一个月,甚至是四个月的记录全部写入同一个数据库的同一个表格,则所有的数据量大的将使表格崩溃,即使数据库能够管理,查询的速度也是可想而知的。将会非常的慢。经过作者反复的思索,想出了一个巧妙的办法,就是以系统的日期作为当天的表格名称。当系统时间为00:00:00时

9、刻时,新建一个表格,通过SQLCreateTable(DeviceID,TableName,TemplateName)函数建立不同的表格。因为组态王支持字符串函数,如下所示: StrASCII(Char);/此函数返回某一指定的文字变量首字符的ASCII值 StrChar(ASCII);/此函数返回某一指定ASCII码所对应的字符 StrFromInt(Integer,Base);/此函数将一整数值转换为另一进制下的字符串表示 StrFromReal(Real,Precision,Type);/此函数将一实数值转换成字符串形式 StrFromTime(SecsSince1-1-70,Strin

10、gType);/此函数将一个时间值转换为字符串 StrInStr(Text,SearchFor,StartPos,CaseSens);/此函数用于查找文本 StrLeft(Text,Chars);/此函数返回指定文字变量的开始(或最左的)若干个字符 StrLen(Text);/此函数返回某一指定的文字变量的长度 StrLower(Text);/此函数将指定文字中的所有大写字母转换为小写字母 StrMid(Text,StartChar,Chars);/此函数从指定的位置开始,从一个文字变量中返回指定个数的字符 StrReplace(Text,SearchFor,ReplaceWith,CaseS

11、ens,NumToReplace,MatchWholeWords); /此函数替换或改变所提供字符串的指定部分 StrRight(Text,Chars);/此函数返回指定文字变量的最末端(或最右)若干个字符 StrSpace(NumSpaces);/此函数在文字变量中或表达式中产生一个空格串 StrToInt(Text);/此函数在文字变量中或表达式中产生一个空格串 StrToReal(Text);/此函数将一个由数字组成的字符串转换成一个能用于数字计算的实数值 StrTrim(Text,TrimType);/此函数删除文字变量中无用的空格 StrType(Text,TestType);/此函

12、数检测文字变量的首字符以确定其是否为某一类型 StrUpper(Text);/此函数将一指定文字变量中所有的小写字符转换成大写字符 在组态王中建立内存型字符变量NameTable=A+StrFromInt(本站点$年,10)+StrFromInt(本站点$月,10)+StrFromInt(本站点$日,10);NameTable的构成为字母A+系统日期。将系统提供的整型变量转换成字符型变量。这样可以在数据库中建立每天的表格。每当系统日期由23:59:59跳变到00:00:00时,执行SQLCreateTable()函数,建立当天的表格,如图10所示,在SQLServer中组态王建立了A20066

13、19日的表格, 图10建立当天的表格4.4基于Active控件的组态王条件查询 为了完成如此复杂的查询,使用了Active控件,因为组态王支持第三方控件,将所有的条件罗列出来进行排列组合,将每一种情况都考虑在内。然后通过程序来实现选择条件转换成SQLSELECT()函数工作的条件。 (1)任意查询任意生产线在任意时段的产量。因为工艺要求能够任意查询任意生产线在任意时段的产量,为了能够实现该功能,新建本站点CX_Hour,本站点CX_Minute,本站点CX_Hour1,本站点CX_Minute1变量。在以时间段进行查询时,先将以前两个变量输入的时间做为条件进行查询,将查询出记录的数据赋给在过程

14、中自定义的中间变量。然后再以后两个变量输入的时间为条件进行查询,将查询出的结果同样赋给自定义的中间变量。将两次查询的结果求差然后,将日期,时间,车间,生产线,产量通过报表的组态添到表格当中。 (2)对于月产量的查询。需要判断输入的月份有几天,然后从该月的第一天开始到最后一天进行查询,查询的时刻为每一天的23:59分时各生产线的产量。然后对查询出的数据进行累加,直到该月的最后一天,然后按照特定的格式将数据填写到报表当中。在该过程中需要灵活的运用循环语句:While以及深刻的体会组态王的变量与数据库进行数据交换的过程。 查询的条件比较复杂,有些条件不能同时成立,因此在选择条件时,应该要互相限制,以避免出现混乱的现象。具体的程序在应用程序命令语言运行时写如下程序: /StringSystime=StrFromInt(本站点$时,10)+:+StrFromInt(本站点$分,10); /=判断早班,中班,晚班和查询的时段= StringTimestr=StrFromInt(本站点$时,10)+StrFromInt(本站点$分,10); LongTimereal=StrToInt(Timestr); if(Timereal=730) if(Timereal=1530)

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号