组态王与ACCESS数据库的数据交换的例子
组态王与Access数据库通讯
组态王与Access数据库通讯1定义ODBC数据源组态王与Access数据库通讯--①定义ODBC数据源定义ODBC数据源组态王SQL访问功能能够和其他外部数据库(支持ODBC访问接口)之间的数据传输。
实现数据传输必须在系统ODBC数据源中定义相应数据库。
1.0 进入“控制面板”中的“管理工具”,用鼠标双击“数据源(ODBC)”选项,弹出“ODBC数据源管理器”对话框,如图19.6所示。
有些计算机的ODBC数据源是中文的(如上图所示),有些的是英文的,视机器而定,但是两种的使用方法相同。
ODBC数据源管理器”对话框中前两个属性页分别是“用户DSN”和“系统DSN”,二者共同点是:在它们中定义的数据源都存储了如何与指定数据提供者在连接的信息,但二者又有所区别。
在“用户DSN”中定义的数据源只对当前用户可见,而且只能用于当前机器上;在“系统DSN”中定义的数据源对当前机器上所有用户可见,包括NT服务。
因此用户根据数据库使用的范围进行ODBC数据源的建立。
2.0 选择系统DSN,然后点击添加,就会跳出如下界面,选择Microsoft Access Driver,点击完成3.0 如下图,跟这个数据源取个别名,这里就叫mysql,然后要选择数据库,如果没有建的话,点击创建(如果你在外面直接右键新建的话可能格式不一样,我新建的是.accdb格式的,直接不支持,所以如果遇到我这种情况,可以直接创建)3.1 新建数据库,会出现以下画面,这里要填几个参数,数据库名,驱动器(放置位置)其他一般默认就可以了,点击确定就完成了一个ACCESS数据库的创建创建格式的数据库,点击确定成了设置5.0 你在刚刚创建数据库的路径,也能看到实际的数据库文件了组态王与Access数据库通讯--②组态王设置组态王定义设置1.0 立项,这里叫TEST项目2.0 选择数据库--数据词典,新建3个变量,DeviceID(内存整数),level1,level2(内存整数),DeviceID是用来存储SQLConnect分配给每个数据库连接的数值3.0 找到左边栏的SQL访问管理器--表格模板,新建一个叫table的模板3.1 如下图,增加4个字段,这个新增的字段就是表格的横向类别,从上到下对应表格的从左到右,字段的顺序会影响表格表头的左右顺序,如果已经创建表格了,再更改这个字段顺序,那边表格的顺序也不会变了,只有删除数据库文件,才会重置表格,关闭数据库不会删除数据库数据4个字段,日期--定长字符串型--32,时间--定长字符串型--32,level1--整型--1,level2--整型--1如下图4.0 如下图选择记录本,新建bind14.1 在记录本上新建4个字段和变量的衔接,比如字段:日期跟变量\\local\$Date,意思就是\\local\$Date变量代表日期,每次插入记录就会记录一次这个变量的值,如下图做四个变量,时间=\\local\$Time,level1=\\local\level1,level2=\\local\level23.组态王画面设置组态王与Access数据库通讯--③组态王画面设置组态王画面设置1.0 首先要做个组态王的按钮画面,新建画面,命名数据库画面,其他先默认好了2.0 如下图,先建立4个按钮,分别为数据库连接,数据库断开连接,创建数据表格,插入记录3.0 另外要给按钮写入命令语言,双击数据库连接按钮,点击按下时,SQLConnect( \\local\DeviceID, "dsn=mysql;uid=;pwd="); ,\\local\DeviceID 为上一期新建的内存整数变量,用来存储SQLConnect 分配给每个数据库的值,(这里注意,SQL 在断开连接之前,重复执行SQLConnect 会增加DeviceID 的值,最大值为255);而dsn 为需要连接的数据库,这里就写上我们在ODBC 数据源配置的数据库,uid 和pwd 账号密码有就设没有就不写;小知识点:在命令语言界面下方,有归总的函数集,SQL里面有很多,双击SQL连接函数,出来是SQLConnect( DeviceID, "dsn=;uid=;pwd=");整体的格式就出来了还是挺方便,双击DeviceID,然后在左下角点击变量,就会跳转到数据词典中的变量,选择你需要的变量就可以直接替代3.1 如上所述,其他几句命令语言分别是断开连接SQLDisconnect( \\local\DeviceID);,创建数据库表格SQLCreateTable(\\local\DeviceID, "表格", "table" );,插入记录SQLInsert( \\local\DeviceID, "表格", "bind1" );都是设置在按下时激活4.数据库测试组态王与Access数据库通讯--④数据库测试数据库测试1.0 打开组态王,点击运行2.0 界面如下,点击数据库连接,创建数据库表格,如果不创建表格,打开数据库文件的话,是空的3.0 找到刚才我们放置的数据库文件,双击打开,就会看到下面的表格,可以看到表格的表头分别是我们在组态王中设置的字段,从左到右分别是日期,时间,level1,level2,这里就说明我们的建表已经完成4.0 再回到组态王界面,点击插入记录三下,你会发现表格中还是空的,怎么样才能看到最新的呢,重新打开表格就可以了4.1 如下图,重新打开后的数据库表格,可以看到我们插入的三次记录,可以看到日期,时间你可以看到秒数的变化,level1和level2的值都是50,60,就是我们设置的初始值,他没有发生变化。
Access数据库和表在 组态王中使用
Access数据库和表
4学时(两次实操课)
主要内容:
数据库的创建、打开、关闭及数据库 属性设置 表的创建、结构修改等基本操作 表中数据录入、编辑等基本操作 表中数据排序、查找、筛选等基本应 用 表间的关系和子数据表的相关操作
1 数据库设计
1.1 创建数据库
A.创建空数据库
B.使用本机或者网络上的模板创建完整的
Access2003中可以根据的一些标准的数据库框 架来创建数据库,这些标准的数据库框架称为模
板。
【例2】用本机上的模板上创建一个“学校讲座 管理”数据库。
操作要点:
在Access2003窗口中,依次单击
【文件】→【新建】菜单命令。
在弹出“新建”对话框中,选择
“数据库”选项卡中的“讲座管 理”模板
性别
出生日期 是否团员 入学时间 班级编号 专业 入学成绩 照片
文本
日期/时间 是/否 日期/时间 文本 文本 数字 OLE对象
2
是
是 是 是
6 10 整型
是 是 是 是
操作要点:
选择“表”对象→“使用设计器创建表”
在“表1:表”表设计器对话框中,输入各字段 、设置主 键。
C.通过数据输入创建表
B.向表内添加记录
向表中添加记录是在表的数据视图窗口 中来完成的,表的最末尾有一条空记录, 在记录的行选定器上显示一个星号(*) 图标,表示可以从这里添加记录。
C.删除记录
删除记录是在表的数据视图中,选择要删 除的记录,然后单击【编辑】→【删除记 录】命令来完成的。
D.修改记录
修改整个字段数据时选择要修改的字段或直 接用【Tab】键移至要修改的字段。 如果只修改字段数据中的某个或几个字符, 可以按【F2】键,来切换单个字符和整个字 段数据的选择。 如修改错误可以通过按【Esc】键或退出表的 数据表视图“不保存”数据来还原数据。
组态王之记录体与ACCESS库
第一步:新建一个Assecc库
1、找到系统的ODBC数据库
位置1:控制面板-系统和安全-管理工具-ODBC数据源-用户DSN-添加-驱动名称中没有Access这个英文的
说明该位置不对
①
②
③
④
1、找到系统的ODBC数据库
位置2:C:\Windows\SysWOW64\odbcad32.exe 如果以上两个位置都无法找到新建一个Assecc数据库,请前往别处参考!!!! 以下步骤一定要找到odbcad32.exe才可进行
• 3、新建3个按钮,分别为:连接ACCESS库、数据写入ACCESS库、断开ACCESS库
组态王三个按钮的命令语言
1、连接ACCESS库:SQL Connect( Device ID, "dsn=数据连接;uid=;pwd=");
SQL Connect:SQL连接(启动)指令; Device ID:项目ID或表格ID,可能代表有几个变量数据写到ACCESS,我没深究; Dsn=数据连接:ODBC数据源名,“ACCESS库新建步骤查看自己的命名”; Uid=:用户;没用就空着 pwd=:密码;没用就空着
2、数据写入ACCESS库:SQL Insert( Device ID, "ACCESS表", "组态王数据" );
SQLInsert: SQL写入指令; ACCESS表:在ACCESS数据库名中的表格名称; 组态王数据:组态王中SQL记录体的名称;
3、断开ACCESS库:SQLDisconnect( DeviceID);
1、
⑥
2、
2、新建ACCESS库
1、添加; 2、选择Microsoft Access Driver(*.mdb)后点击“完成”; 3、 ①数据源名:自命名
CP243-1连接组态王力控KEPSERVERPC ACCESS
CP243-1的连接资源为8个S7连接+ 1个PG连接,PG连接即为S7200编程软件1、配置CP243-1模块连接数目即为S7连接的个数(如果没有上位机,仅是PLC 编程软件上下载程序、监控,此处可以填0)CP243-1与组态王或是力控连接的时候,CP24-1是作为服务器的,第一个连接,本地TSAP 默认是10.00且不能修改,远程TSAP可以修改,使用默认即可,此时本地TSAP与远程TSAP相同,都为10.00勾选接受所有请求连接请求,点击下一个连接,配置与此类似。
(如下图所示)注意:2个连接的远程TSAP尽量不要相同,否则当连接数目多的情况下,某些连接通讯会失败。
TSAP地址包含两部分,第一部分:通信连接号,建议(10-99)10以下不行;第二部分:CP243-1模块安装在S7-200的机架/槽号,如“00” 代表CP243-1安装在0号机架0号槽(即CPU之后的第一个模块)本例远程TSAP分别为10.00和11.00。
切记:配置完成后CP243-1模块重新上电,使配置生效!2、配置力控IO设备组态设备IP地址即为CP243-1的IP地址,下图是配置CP243-1时的IP地址,两者应对应。
端口号:102,切勿修改,否则无法通信TSAP(PLC)与配置CP243-1时的本地TSAP 对应,TSAP(PC)与配置CP243-1时的远程TSAP 对应。
3、配置组态王IO设备组态格式为CP243-1的IP地址:0,如上图:192.168.1.110:0 CP243-1与组态王通信默认占用的是PG资源,如果还需要PLC编程软件监控程序,则需要修改组态王DRIVER文件夹下KVS7200的配置文件,如下图所示第一行[CP243-1的IP地址:0];第二行LocalTSAP的值与配置CP243-1远程TSAP对应;第三行RemoteTSAP的值与配置CP243-1本地TSAP对应;如果LocalTSAP=4D57 RemoteTSAP=4D57则此时通信占用了CP243-1的PG资源。
组态王和Access数据库交互(1)
组态王和Access数据库交互新建一个access数据库文件,mdb格式或者accdb都可以然后在里面建立一个表,命名为table1,插入几个字段如下图。
姓名格式为文本,年龄格式是长整型,成绩为单精度型也就是小数,点击保存2.建立odbc数据源依次点击计算机->控制面板->管理工具->数据源(odbc)第一步:第二步:然后点击系统DNS点击添加找到驱动点击完成。
输入数据源名称点击选择找到你建立的数据库然后点击确定打开组态王新建三个变量姓名:内存字符串年龄内存实数(也可以为整数)成绩内存实数点击记录体插入三个字段字段名称必须和数据库名称一样,但是数量不必相同,你可以只建姓名跟年龄字段,成绩不建也能插入数据库然后建立一个内存整形变量DeviceID在画面建立三个输入框当按下时插入记录按钮代码如下dsn=所建立的dsn名称table1是数据库表名T1是记录体名称点击插入记录试一下输入小数的年龄可以看到年龄四舍五入了2,查询数据库插入控件并且改一下名字然后右键选择控件属性点击浏览点击连接找到你的数据源点击确定。
新建一个查询按钮插入一下命令SQLConnect( DeviceID, "dsn=linjjl;uid=;pwd=");查询表.Where="姓名='linjjl'";查询表.FetchData();查询表.FetchEnd();SQLDisconnect( DeviceID);注意查询表.Where 双引号里面的内容姓名=’linjjl’注意单引号在画面上新建一个字符串输出变量把查询表.Where 显示一下方便调试点击查询查询上面是查询表.Where 字符串的内容我们可以根据输入内控查询先在数据库增加几条内容在组态王新建一个字符串变量查询的姓名然后在画面上做一个字符串输入查询按钮的代码改一下注意姓名后面有个单引号最后双引号里面有个单引号组态王中字符串拼接用+ 号运行一下多加一个查询条件年龄=5时排序按成绩排序为了试验先把数据库里的成绩改一下然后改一下组态王代码运行情况如下看看Id号反过来了判断单元格是不是空行如图建立几个单元格为空的行改一下查询语句注意空检测的语句IsNull()区分大小写就这么写小写是错的查询结果更新数据库把上次我们查到的成绩为空的改成100 新建一个变量初始值改成100然后再见一个记录体再画面新建一个按钮更新成绩运行一下完。
组态王通过数据库Access实现数据的采集与输出
组态王通过数据库access实现数据的采集与输出前提:➢数据库用Microsoft Office Access 2003,数据库路径为D:\历史记录.mdb➢组态王版本为6.53➢PC机系统为XP一、创建数据库表1. 新建名为“历史记录”的数据库,新建完成后,打开数据库2. 创建表,点击使用设计器创建表,进入设计视图对话框,输入字段名日期时间、毫秒、污泥浓度、溶氧仪、进水COD、电磁流量计、超声波流量计、二在线COD,其中字段名日期时间的数据类型为日期/时间、毫秒的数据类型为数字长整型、其他字段名数据类型为数字单精度型。
3. 保存名为:10分钟记录二、创建ODBC打开控制面板→管理工具→数据源(ODBC),弹出“ODBC数据管理器”,在用户DSN标签下,点击添加弹出“创建数据库源”选择此项创建数据库源完成后弹出输入数据源名称选择之前创建的数据库确定完成。
三、组态王内部设置1. 新建变量在数据词典中创建本地变量,,变量名称分别为日期时间、DeviceID、nReturnValue。
2. 打开到组态王工程浏览器,新建记录体创建名为“历史记录”的记录体3. 创建事件命令语言点击创建,弹出事件命令语言对话框事件描述为:(((\\本站点\$分)%10==0)&&((\\本站点\$秒-1)%60==0))==1 4. 创建应用程序命令语言输入记录体名称字段名称要与数据库中的名称相一致添加数据词典中已存在的变量显示已增加的字段10分钟记录一次每10分钟操作一次该命令5. 使用趋势来读取数据库数据新建趋势画面,趋势控件为历史趋势控件,选中控件并鼠标右击选择“控件属性”,进入“设置数据库曲线”对话框在“运行”时标签栏下输入刷新时间输入该命令行点击此按钮,添加数据库中的变量添加好的数据附录:若要做报表通过读取数据库的数据,则使用通用控件中的KVADODBrid Class 。
并制作查询按钮,脚本如下:\\本站点\nReturnValue=Ctrl.QueryDialog(); if (\\本站点\nReturnValue==1) { Ctrl.FetchData();}选择表名称选择数据库中的“日期时间” 选择数据库中的“毫秒”选择数据库中的要显示的趋势数据选择线颜色输入最大值、最小值。
组态王与数据库连接的实现方法
4.设置完毕后关闭此对话框,利用按钮的弹起时命令语言实现数据库查询,操作设置如图11:
图11
5.
设置完毕依次点击确定。保存画面并且换到运行系统可看到如图12效果。
图12
6.用同样方法创建一个“清除记录”按钮用于清除数据库表格中的记录,命令语言如下:
SQLClearTable( DeviceID, "biaoge1");
图5
1.3
注意:记录体中的字段名称必须与表格模板中的字段名称保持一致,记录体中字段对应的变量数据类型必须和表格模板中相同字段对应的数据类型相同。
1.在工程浏览器窗口“数据库\数据词典”中新增三个内存字符串型变量(ziduan1、ziduan2、ziduan3)。
2.找到工程浏览器窗口左侧“SQL访问管理器\记录体”选项,双击右侧“新建”图标建立名为“jiluti1”的记录体,对话框设置如图6所示:
2.在数据库操作画面中添加一个名为“字段一”的文本
3.在“字段一”的动画连接中添加对应类型的值输入和值输出并关联到变量:ziduan1。
4.添加文本“字段二”、“字段三”,分别关联变量“ziduan2”、“ziduan3”并添加值输入、值输出动画连接。
5.添加一按钮,按钮文本为“插入记录”在按钮的弹起事件中输入如图6所示命令语言。
图6
依次增加ziduan1、ziduan2、ziduan3三个字段点击“确认”。
2
2.1
1.在工程浏览器窗口“数据库\数据词典”中定义一个内存整型变量:
变量名:DeviceID
变量类型:内存整型
2.在工程浏览器窗口的“命令语言\应用程序命令语言\启动时”窗口输入命令:
SQLConnect( DeviceID, "dsn=yuan;uid=;pwd=");
组态王与Access数据库的数据交换
SQLNext(DeviceID); 选取选择集中的下一条记录。
SQLPrev(DeviceID); 选取选择集中的上一条记录。
SQLLast(DeviceID); 选取由SQLSelect()创建的选择集的末条记录。
DeviceID SQLConnct()产生的连接号
6.断开数据库
SQLInsert(ConnectionID, “kingview”, “bind1”)
4.得到选择集
函数SQLSelect(DeviceID, TableName, BindList, WhereExpr, OrderByExpr);
函数说明:
DeviceID SQLConnct()产生的连接号
参数说明:
DeviceID SQLConnct()产生的连接号
TableName 想要创建的数据库的表格名
TemplateName 表格模板名
例子:下例创建一个名为kingview的新表,模板为table1
SQLCreateTable(DeviceID, “kingview”, “table1”)
1.连接数据库
函数SQLConnect( DeviceID, "dsn=;uid=;pwd=");
参数说明:
DeviceID SQLConnct()产生的连接号
"dsn=;uid=;pwd=" 连接语句,包括 ODBC中定义的数据源名、用户名和密码,用户名和密码可以缺省。
组态王与Access数据库的数据交换
SQL访问管理器
SQL访问管理器用来建立数据库列和组态王变量之间的联系。包括表格模板和记录体两部分功能。通过表格模板在数据库表中建立表格;通过记录体建立数据库表格列和组态王之间的联系,允许组态王通过记录体直接操纵数据库中的数据。表格模板和记录体都是在工程浏览器中建立的。
组态王与ACCESS数据库的数据交换的例子
组态王与ACCESS数据库的数据交换——以中山创污水处理为例一、创建表格模板和记录体。
在组态王工程浏览器中的SQL访问管理器点击表格模板。
在右侧目录内容中双击“新建”创建一个名称为“1”且字段为“工号”“日期”“时间”“酸”“碱”“混凝剂”“还原剂”“氯化钙”“PAM正”“PAM负”的表格。
注意:当编辑字段名称时,应与新建组态王变量一样(最好不要用字符),不含非法字符,如:“+”“-”“=”“#”等。
此表格格式决定了ACCESS数据库的表格格式。
同样在SQL管理器中点击记录体,在右侧目录内容中双击“新建”,创建一个名称为“1”的记录体。
其字段名称与表格模板中的字段相对应。
组态王变量是连接的组态王内部变量。
编辑字段名称的规则与编辑表格模板一样。
二、建立MS ACCESS数据库。
1.建一个空的ACCESS数据库,定名为20,保存在D:\29所污水处理工程。
2.定义数据源双击控制面板下的“ODBC数据源(32位)”选项,弹出“ODBC数据源管理器”对话框。
选择“用户DSN”属性页,并单击“添加”按钮。
在弹出的“创建新数据源”对话框中,选择“Mirosoft Access Driver”单击“完成”按钮。
弹出“ODBC Microsoft Access安装”对话框,定义数据源名为“20”单击“选择”按钮,从中选择路径D:\29所污水处理工程\20.MDB单击“确定”按钮,完成对数据源的配置。
三、组态王开发界面的组态在组态王开发系统中创建如下画面:其中表格为KV ADODBGrid CLASS控件。
四、对数据库的操作。
点保存弹出对话框。
在“确定”按钮的动画连接向导的“弹起时”输入命令语言SQLConnect( \\本站点\ID, "dsn=20;DATABASE=20;uid=;pwd=");//连接名称为“20”,数据源名称为“20”的数据库。
SQLCreateTable( \\本站点\ID, "10", "1" );//在数据库“20”内创建名称为“10”的表格,表格模板名称为“1”表格模板在组态王中已编辑。
基于组态王之间的数据交换,设置步骤
连接架构说明:举例说明1、I/O数据采集(下属站点)负责数据采集处里,组态王与PLC通讯连接采集现场实时数据,传到下属站电脑上。
(长堤)2、数据访问(上位中心)通过网络(局域网)与下属站点的电脑网络共享通讯调取下属站点的单点变量数据,实时读取及控制。
(桩一接转站监控中心)具体操作过程:1、组建下属站点与上位中心局域网共享工作组,使下属站点与上位中心都在一个工作组中,能够互相查看调取对方共享的文件。
操作步骤1.在上位中心电脑上组建工作组,电脑桌面我的电脑右击属性—计算机名---键入计算机描述名-------点击更改-----键入计算机名-------键入工作组名----单机确定------重启计算机。
上位机工作编辑完成。
2.下属站点电脑步骤同上,工作名改为上位中心电脑编辑的工作名。
3.将两者需要共享的文件设为共享,双方电脑就可以互相查看共享的文件了。
2、下属站点安装组态王运行软件,编写好工程程序,将工程所属的直接文件夹设为共享,单机组态王网络配置-----点击网络参数----设为连网-----键入本机节点名(计算机名或IP地址)-----点击节点类型-------本机是登录服务器、本机是I/O服务器、进行数据类型备份,都打钩。
---点击确定退出。
3、上位中心安装组态王运行程序,新建空白工程程序,单机组态王网络配置----点击网络参数-----设为连网------键入本机节点名(计算机名或IP地址)-----点击节点类型------本机是登录服务器打钩-------点击确认退出对话框—点击组态王站点-------新建远程站点---------点击读取节点配置----从网上邻居,整个网络选择下属站点共享的工程程序文件-----点击确认----此时下属站点的工程参数将显示在新建远程站点中------点击组态王系统-----点击网络配置------点击节点类型----勾掉本机是登录服务器----在右选框中选择下属站点的名称-------本机是I/O服务器打钩---报警服务器、历史记录服务器都打勾-----点击客户配置-----客户打勾----I/O服务器打勾----点击确认退出对话框。
组态王与Access数据库连接
组态王与Access数据库连接第九讲组态王与Access数据库连接 90第九讲组态王与Access数据库连接在本课程您将:, 了解组态王SQL访问管理器。
, 了解如何与通用数据库进行连接, 了解如何想向数据库插入记录组态王SQL访问功能实现组态王和其他外部数据库(支持ODBC访问, 了解如何查询数据库中记录接口)之间的数据传输。
它包括组态王的SQL访问管理器和SQL函数。
,以Ms Access数据库为例,下面说明组态王与其相连的例子。
北京亚控科技发展有限公司第九讲组态王与Access数据库连接 91SQL访问管理器SQL访问管理器用来建立数据库列和组态王变量之间的联系。
包括表格模板和记录体两部分功能。
通过表格模板在数据库表中建立表格;通过记录体建立数据库表格列和组态王之间的联系,允许组态王通过记录体直接操作数据库中的数据。
表格模板和记录体都是在工程浏览器中建立的。
北京亚控科技发展有限公司第九讲组态王与Access数据库连接 92创建表格模板,在工程浏览器中左侧工程目录显示区中选择“SQL访问管理器”下的“表格模板”项,在右侧目录内容显示区中双击“新建”,弹出“创建表格模板对话框”,如下图。
在表格模板中建立五个记录,字段名称,变量类型,变量长度,索引类型分别如上图所示。
建立表格模板的目的在于定义一种格式,在后面用到是SQLCreatTable ()以次格式在Access数据库中建立表格。
北京亚控科技发展有限公司第九讲组态王与Access数据库连接 93创建记录体在工程浏览器左侧的工程目录显示区中选择SQL访问管理器下的记录体,在右侧的目录内容显示区中双击“新建”,弹出“创建表格模板对话框”,如下图。
记录体定义了组态王变量$日期、$时间、原料油液位、催化剂液位、成品油液位和Access数据库表格中相应字段日期、时间、原料油液位值、催化剂液位值、成品油液位值之间的对应连接关系。
(注意:记录体中的字段名称和顺序必须与表格模板中的字段名称和顺序必须保持一致,记录体中的字段对应的变量的数据类型必须和表格模板中相同字段对应的数据类型相同。
组态王与数据库的链接
上一条记录:SQLPrev( DeviceID );
最后一条记录:SQLLast( DeviceID );
断开数据库: SQLDisconnect ( DeviceID )。
建一个Microsoft Access Driver(*.mdb)驱动的数据源,名为:mine。
双击“数据源 (ODBC)” →“系统DSN” → “增加” → “Microsoft Access
Driver(*.mdb)”驱动程序“→完成”。
输Байду номын сангаас数据源名称:mine
选择数据库
选中该项,将在前面的方框中
3)插入记录
SQLInsert( DeviceID, "KingTable", "Bind1" );
SQLInsert
在表格中插入一个新的记录。
语法:
[ResultCode=]SQLInsert(DeviceID, "TableName", "BindList");
参数描述
DeviceID:SQLConnct()产生的连接号
1)连接数据库
• 在工程浏览器窗口的数据词典中定义一个内存整型变量:
DeviceID
• 新建一画面,名称为:数据库操作画面。
• 在画面上输入文字:数据库操作。
• 在画面中添加一按钮,按钮文本为:数据库连接。
• 在按钮的弹起事件中输入如下命令语言:
SQLConnect( DeviceID, "dsn=mine2;uid=;pwd=");
TableName: 表格名
BindList:记录体
组态王与Access数据库连接的配置及使用说明
组态王与Access数据库的数据交换SQL访问管理器SQL访问管理器用来建立数据库列和组态王变量之间的联系。
包括表格模板和记录体两部分功能。
通过表格模板在数据库表中建立表格;通过记录体建立数据库表格列和组态王之间的联系,允许组态王通过记录体直接操纵数据库中的数据。
表格模板和记录体都是在工程浏览器中建立的。
创建表格模板在工程浏览器中左侧工程目录显示区中选择“SQL访问管理器”下的“表格模板”项,在右侧目录内容显示区中双击“新建”,弹出“创建表格模板”对话框,如下图。
建立表格模板的目的在于定义一种格式,在后面用到是SQLCreatTable(),以次格式在Access数据库中建立表格。
创建记录体在工程浏览器中左侧工程目录显示区中选择“SQL访问管理器”下的“记录体”项,在右侧目录内容显示区中双击“新建”,弹出“创建记录体”对话框,如下图。
其中: 字段名称填写数据库表格中的列名。
组态王变量填写和表格中指定列相关联的组态王变量。
建立Ms Access数据库 1.建立一空Access文件,定名。
2.定义数据源 双击控制面板下的“ODBC数据源(32位)”选项,弹出“ODBC数据源管理器”对话框。
选择“用户DSN”属性页,并单击“添加”按钮。
在弹出的“创建新数据源”对话框中,选择“Mirosoft Access Driver”单击“完成”按钮。
弹出“ODBC Microsoft Access安装”对话框,定义数据源名。
单击“选取”按钮,从中选择相应路径下刚刚定义的数据库文件。
单击“确定”按钮,完成对数据源的配置。
对数据库的操作 首先在数据词典里建立变量DeviceID,为内存整形,是数据库连接时产生的连接号。
1.连接数据库 函数SQLConnect( DeviceID, "dsn=;uid=;pwd="); 参数说明: DeviceID SQLConnct()产生的连接号 "dsn=;uid=;pwd=" 连接语句,包括 ODBC中定义的数据源名、用户名和密码,用户名和密码可以缺省。
组态王连接Accesss大数据库与历史曲线显示
我是依据组态王帮助文件里面的案例,不过我写的会更详细!以某工业现场应用为例,需要对原料进行称量,并记录原料的生产厂家、原料编号、称量日期、称量时间,值班人员、原料重量。
针对这种关系数据,使用组态王的历史库是无法记录的,因此我们使用关系数据库Access 进行记录。
下面就以此为例来演示完成这一现场需求的设置步骤。
操作步骤:1、新建数据库以及表:1.1)在Access 中新建一个空数据库,例如建立路径为:D:\数据库存储例程\数据.mdb。
1.2)在数据库D:\数据库存储例程\数据.mdb 中创建一个数据表:表的名称为:原料数据。
字段为:称量日期、称量时间、原料重量、原料厂家、原料编号、值班人员、datetime(这个变量是我自己需要历史曲线用的)。
如下图所示:(下面的值是我测试的)其中原料重量字段类型为“数字”设置为“单精度”,datetime设置为日期/时间默认值改为now()。
其余为“文本”类型。
(这里默认的视图是数据表视图,要切换到设计视图,如图所示:)在这下面设置字段大小为单精度型,小数位数为2(这个按自己需求设置位数)。
2、设置ODBC 数据源:2.1) 在“控制面板”-----“管理工具”----“ODBC 数据源”中建立ODBC 数据源,点击“ODBC数据源”弹出“ODBC 数据源管理器”,如下图所示:(这里注意的是如果系统是64位系统的话,则打开C:\Windows\SysWOW64\odbcad32.exe)2.2) 在“用户DSN”中点击“添加”,弹出“选择数据源驱动程序”窗口,如下图所示:选择“Microsoft Access Driver (*.mdb)”驱动,点击“完成”。
弹出如图所示窗口,填写ODBC数据源的名称,根据需要对数据源进行命名,如“数据”,点击“选择(S)”,如图所示,选择我们前面定义的数据库文件“D:\数据库存储例程\数据.mdb”。
点击“确定”完成ODBC 数据源的定义,如图所示。
组态王与数据库连接
组态王与数据库连接实例1、创建数据源及数据库点击鼠标右键菜单,新建一个新建Microsoft Office Access 应用程序,然后双击次图标,打开之后新建一个空数据库,如图9-0:图9-0ODBC 数据源的建立文件名称为mydb10.mdb,选择保存路径(路径:e:\),点击创建。
2、创建数据源及数据库首先外建一个数据库,这里我们选用Access 数据库(路径:e:\,数据库名为:mydb10.mdb)。
然后,用Windows 控制面板>管理工具>数据源ODBC Data Sources (32bit)>新建一个Microsoft Access Driver(*.mdb)驱动的数据源,名为:mine,然后配置该数据源,指向刚才建立的Access 数据库(即mydb10.mdb),如图9-1 所示:图9-1ODBC 数据源的建立3、创建表格模板A、在工程浏览器窗口左侧“工程目录显示区”中选择“SQL 访问管理器”中的“表格模板”选项,在右侧“目录内容显示区”中双击“新建”图标弹出创建表格模板对话框,在对话框中建立三个字段,如图9-2 所示:图9-2 创建表格模板对话框B、单击“确认”按钮完成表格模板的创建。
建立表格模板的目的是定义数据库格式,在后面用到SQLCreatTable()函数时以此格式在Access 数据库中自动建立表格。
4、创建记录体A、在工程浏览器窗口左侧“工程目录显示区”中选择“SQL 访问管理器”中的“记录体”选项,在右侧“目录内容显示区”中双击“新建”图标弹出创建记录体对话框,对话框设置如图9-3 所示:图9-3 创建记录体对话框记录体中定义了Access 数据库表格字段与组态王变量之间的对应关系,对应关中;将\\本站点\$温度1变量值写到Access 数据库表格温度1字段中;将\\本站点\时间1写到Access 数据库表格时间1字段中;将\\本站点\曲线步数写到Access 数据库表格曲线步数字段中;B、单击“确认”按钮完成记录体的创建。
电子课件-《工业组态软件应用技术——组态王6.5》-B02-1994 项目八 任务2组态王与Access数据库连接
项目八 水箱水位组态监控系统设计
表8-2-1 表的字段名称
字段名称 AlarmDate
AlarmTime
AlarmType AcrDate AcrTime EventType VarName
AlarmValue
LimitValue
数据类型 文本
文本
文本 文本 文本 文本 文本
文本
文本
说明 报警日期
项目八 水箱水位组态监控系统设计
三、运行调试
1.单击开发系统菜单栏中文件/切换到View,进入组态王运 行系统。
2.以经理身份登录,按下运行按钮,设备处于运行状态。 3.将供水箱水位模拟游标调至最小位置与最大位置,将水 池水位模拟游标调至最小位置与最大位置。 4.打开报警画面,观察并记录报警画面中记录的报警与事 件内容。
报警时间
报警类型 事件日期 事件时间 事件类型 变量名
报警值
限值
字段名称 ResumeValue OperatorNam
e Quality
Pri GroupName VarComment MachineName IOServerNam
e ResumeValue
数据类型 文本
说明 恢复值
文本
操作员名
文本 文本 文本 文本 文本
项目八 水箱水位组态监控系统设计
任务2 组态王与Access数来自库连接学习目标1.了解组态王SQL访问管理器。 2.掌握组态王与Access数据库的连接。
项目八 水箱水位组态监控系统设计
任务引入
很多工业现场要求将变量的报警信息进行存储,并且可 以灵活地进行历史报警的查询与打印。组态王支持通过 ODBC 接口将数据存储到关系数据库(可以为Access 数据 库或者SQLServer 数据库)中,并且提供KVADODBGrid 控件对存储的历史报警信息进行条件查询,并可以对查询 结果进行打印。本任务要求组态王与Access数据库进行连 接访问,实现对报警、事件信息的存储与查询。
组态王应用——组态王对关系数据库的查询
组态王对关系数据库的查询配置参考文档北京亚控科技发展有限公司技术部目录一、功能概述 (3)一、功能概述 (3)二、工程实例 (3)三、操作步骤: (3)1、数据库以及表: (3)2、设置ODBC数据源: (3)3.利用SQL函数进行查询: (7)3.1) 定义变量: (7)3.2) 定义记录体: (7)3.3) 建立组态王与数据库的关联: (7)3.4) 查询数据库: (9)3.5) 进入运行系统: (11)4.利用KV ADODBG RID控件进行查询: (11)4.1) KVADODBGrid控件的介绍: (11)4.2) KVADODBGrid控件的使用: (12)4.3) 进入运行系统: (17)四、注意事项 (17)图表图一原料数据表 (4)图二 ODBC数据源管理器 (5)图三选择数据源的驱动程序 (5)图四数据源定义 (6)图五选择数据库 (6)图六 ODBC数据源定义 (6)图七定义记录体 (7)图八建立与数据库的连接 (8)图九断开与数据库的连接 (9)图十组态王画面 (10)图十一运行系统画面 (11)图十二插入通用控件 (12)图十三 KV控件属性 (13)图十四数据链接属性 (14)图十五KV控件配置 (14)图十六KV控件 (15)图十七KV控件 (16)图十八 KV ADODBGrid控件查询画面 (16)图十九 KV ADODBGrid控件运行画面 (17)一、功能概述常规需求:很多工业现场要求对关系数据库的数据根据不同的条件进行查询处理。
组态王中的实现方法:1、利用组态王的SQL函数实现对数据库的数据的查询处理。
2、利用组态王的KV ADODBGrid控件实现对数据库的查询处理。
这两种实现方法的不同之处在于:第一种方式是将查询结果对应到组态王的变量上,可以通过组态王的变量进行相关的计算处理以及在命令语言中使用,但是如果符合条件的记录有许多条则无法同时看到所有的查询选择结果。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
组态王与ACCESS数据库的数据交换
——以中山创污水处理为例
一、创建表格模板和记录体。
在组态王工程浏览器中的SQL访问管理器点击表格模板。
在右侧目录内容中双击“新建”创建一个名称为“1”且字段为“工号”“日期”“时间”“酸”“碱”“混凝剂”“还原剂”“氯化钙”“PAM正”“PAM负”的表格。
注意:当编辑字段名称时,应与新建组态王变量一样(最好不要用字符),不含非法字符,如:“+”“-”“=”“#”等。
此表格格式决定了ACCESS数据库的表格格式。
同样在SQL管理器中点击记录体,在右侧目录内容中双击“新建”,创建一个名称为“1”的记录体。
其字段名称与表格模板中的字段相对应。
组态王变量是连接的组态王内部变量。
编辑字段名称的规则与编辑表格模板一样。
二、建立MS ACCESS数据库。
1.建一个空的ACCESS数据库,定名为20,保存在D:\29所污水处理工程。
2.定义数据源
双击控制面板下的“ODBC数据源(32位)”选项,弹出“ODBC数据源管理器”
对话框。
选择“用户DSN”属性页,并单击“添加”按钮。
在弹出的“创建新数据源”对话框中,选择“Mirosoft Access Driver”单击“完成”按钮。
弹出“ODBC Microsoft Access安装”对话框,定义数据源名为“20”
单击“选择”按钮,从中选择路径D:\29所污水处理工程\20.MDB
单击“确定”按钮,完成对数据源的配置。
三、组态王开发界面的组态
在组态王开发系统中创建如下画面:
其中表格为KV ADODBGrid CLASS控件。
四、对数据库的操作。
点保存弹出对话框。
在“确定”按钮的动画连接向导的“弹起时”输入命令语言
SQLConnect( \\本站点\ID, "dsn=20;DATABASE=20;uid=;pwd=");
//连接名称为“20”,数据源名称为“20”的数据库。
SQLCreateTable( \\本站点\ID, "10", "1" );
//在数据库“20”内创建名称为“10”的表格,表格模板名称为“1”表格模板在组态王中已编辑。
SQLInsert( \\本站点\ID, "10", "1" );
//在名称为“10”的表格内插入名称为“1”的记录体。
记录体在组态王中已编辑。
ClosePicture("手动确定");
//关闭“手动确定”画面。
数据库中的被记录变量必须要先被当前组态画面显示后才能在数据库中记录下来。
(本工程中要记录的变量已经在KV ADODBGrid CLASS控件上方显示过了,即褐色的部分,显示后再点击“保存”按钮,进入保存对话框,点击“确定”按钮,数据才能进入数据库。
五:进入组态王运行状态,点击保存弹出对话框,点击“确定”按钮;将会自动在Microsoft Access 中生成名字为“10”的数据库表格;
六:进入Microsoft Access中,打开D:\29所污水处理工程\20.MDB,就会看到自动生成的名字为“10”的数据库表格
七、创建KV ADODBGrid CLASS控件
1.在画面中插入控件:组态王画面菜单中编辑\插入通用控件,或在工具箱中单击“插入通用控件”按钮,在弹出的对话框中选择 KVDBGrid Class,单击确定。
2.按下鼠标左键,并拖动,在画面上绘制出表格区域。
3.双击控件。
弹出KVADODBGrid CLASS控件动画连接属性。
在控件名那栏填上“手动历史数据库”。
注意:控件名最好为汉字。
4.设置控件属性:选择控件右键菜单中“控件属性”。
弹出控件固有属性页,可分别设置如下属性:
(1)、数据源:
单击“浏览”按钮可选择已建的ODBC数据源“20”。
选择数据源后“表名称”组合框中就自动填充了可选的表名称,可弹出下拉列表选择要显示的数据所在的表名称“10”。
选择表名称后,“有效字段”中自动填充表中的所有字段“工号”“日期”
“时间”“酸”“碱”“混凝剂”“还原剂”“氯化钙”“PAM正”“PAM负”,
可通过“添加”、“删除”,“上移”,“下移”按钮来选择要显示的字段和
显示顺序。
单击显示的字段,可在右侧设置字段显示的标题、格式、对齐等属性。
(2)、表格属性:
可设置表格的一般属性。
说明:如固定行数大于1,则第一行显示选择字段的标题,其它固定行不
自动填充,要由使用者在设计状态编辑其显示内容。
(3)、颜色:
可设置表格颜色,背景颜色,文本颜色等信息。
(4)、字体:
可设置固定行字体,普通行字体,打印页眉,页脚,标题字体。
(5)、打印设置:
可设置打印标题,页眉,页脚及其位置。
页码格式和位置。
分页位置等。
5.KVADODBGrid CLASS控件方法。
(1)显示数据库表格查询数据
在“显示”按钮的动画连接向导的“弹起时”输入命令语言
手动历史数据库.FetchData();
手动历史数据库.FetchEnd();
(2)表格中字段“工号”“日期”“时间”“酸”“碱”“混凝剂”“还原剂”“氯化钙”“PAM正”“PAM负”的累加值。
在“累积”按钮的动画连接向导的“弹起时”输入命令语言LONG a;
a=3;
\\本站点\酸累积值=手动历史数据库.SumInField(a);
LONG b;
b=4;
\\本站点\碱累积值=手动历史数据库.SumInField(b);
LONG c;
c=5;
\\本站点\混凝剂累积值=手动历史数据库.SumInField(c);
LONG d;
d=6;
\\本站点\还原剂累积值=手动历史数据库.SumInField(d);
LONG e;
e=7;
\\本站点\CACL2累积值=手动历史数据库.SumInField(e);
LONG f;
f=8;
\\本站点\PAM正累积值=手动历史数据库.SumInField(f);
LONG g;
g=9;
\\本站点\PAM负累积值=手动历史数据库.SumInField(g); (3)查询表中数据。
在“查询”按钮的动画连接向导的“弹起时”输入命令语言手动历史数据库.QueryDialog();注:6.5版本无此命令. (4)刷新表中数据
在“刷新”按钮的动画连接向导的“弹起时”输入命令语言手动历史数据库.RefreshData();
(5)打印表格
在“刷新”按钮的动画连接向导的“弹起时”输入命令语言手动历史数据库.Print();。