当前位置:首页 » 编程语言 » 采集设备数据到sql
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

采集设备数据到sql

发布时间: 2023-02-09 08:19:08

❶ 如何将pdf 中的数据快速导入到sql server 中,类似下图中的数据一样。

这个东西很复杂。
首先,要做数据的结构化处理 。你可以将PDF数据先转成word。然后再建个EXCEL表将WORD转到excel。
其次,利用sqlserver的数据导入工具将excel数据转成SQLSERVER数据。

❷ 远程数据采集系统设计,数据传输到上位机。通过3G无线传输,传到监控中心后,怎么把数据存储SQL数据库

数据中心动态库说明

1、数据类型

typedefUINT u32t;

typedefUCHAR u8t;

typedefUSHORT u16t;

typedefULONG u64t;

2、数据结构

1) 用以区分标识各台DTU的数据结构

typedefstruct_modem_info_t_

{

u32t m_modemId; //Modem模块的ID号

u8t m_phoneno[12]; //Modem的11位电话号码,必须以''字符结尾

u8t m_dynip[4]; //Modem的4位动态ip地址

u64t m_conn_time; //Modem模块最后一次建立TCP连接的时间

u64t m_refresh_time; //Modem模块最后一次收发数据的时间

}ModemInfoStruct;

2) DTU数据包的数据结构

#defineMAX_RECEIVE_BUF1450

typedefstruct_modem_data_t

{

u32t m_modemId; //Modem模块的ID号

u64t m_recv_time; //接收到数据包的时间

u8t m_data_buf[MAX_RECEIVE_BUF+1]; //存储接收到的数据

u16t m_data_len; //接收到的数据包长度

u8t m_data_type; //接收到的数据包类型,

// 0x01:用户数据包

// 0x02:对控制命令帧的回应

}ModemDataStruct;

以上u64t类型的时间是基于GMT时间1970年1月1日0:00:000以来的秒数指示时间值,即当前时间距1970年1月1日0点0分0秒以秒为单位的数值。在大多数语言都提供转换函数。

3、API函数说明

1) BOOLDSStartService(u16tuiListenPort);

功能:启动服务器的数据服务

参数:u16ListenPort:服务的侦听端口

返回:成功返回TRUE,失败返回FALSE;

说明:启动服务器的数据服务。启动数据服务后,服务器侦听在指定端口。

如果失败了,可以调用DSGetLastError()函数查看错误原因。

2) BOOLDSStopService(void);

功能:停止服务器的数据服务

参数:无

返回:成功返回TRUE,失败返回FALSE;

说明:停止服务器的数据服务。所有的DTU都将下线。

如果失败了,可以调用DSGetLastError()函数查看错误原因。

3) BOOLDSGetNextData(ModemDataStruct*pDataStruct,u16twaitseconds);

功能:读取下一条DTU送上来的信息

参数:pDataStruct:存放DTU所送上来的信息和数据的结构,读函数执行成功后,返回的数据存放到该参数指向的结构中

waitseconds:本函数读到数据后立即返回;如果没有数据到达,则等待最长waitseconds(时间单位:秒)的时间,直到有数据到达,取值范围从0~65535,如果取值为0表明本函数将立即返回。另外,当在另一个线程中执行成功了DSStopService()后,本函数将立即返回。

返回:成功返回TRUE,失败返回FALSE;

说明:如果失败了,可以调用DSGetLastError()函数查看错误原因。

4) BOOLDSSendData(u32tmodemId,u16tlen,u8t*buf);

功能:向指定ID号的的DTU发送数据

参数:modemId:DTU的ID号,用以标识一个DTU

len:待发送的数据长度(字节数),数据长度必须小于或等于1450个字节

buf:待发送的数据

返回:成功返回TRUE,失败返回FALSE;

说明:如果失败了,可以调用DSGetLastError()函数查看错误原因。

5) BOOLDSSendControl(u32tmodemId,u16tlen,u8t*buf);

功能:向指定ID号的的DTU发送控制命令

参数:modemId:DTU的ID号,用以标识一个DTU

len:待发送的控制命令长度(字节数),数据长度必须小于或等于1000个字节

buf:待发送的控制命令帧

返回:成功返回TRUE,失败返回FALSE

说明:如果失败了,可以调用DSGetLastError()函数查看错误原因。]

6) u32tDSGetModemCount(void);

功能:取得当前在线的所有的DTU的总数

参数:无

返回:得到在线的DTU的数量

7) BOOLDSGetModemByPosition(u32tpos,ModemInfoStruct*pModemInfo);

功能:取得指定位置的DTU的数据;

参数:pos:DTU列表中的位置信息,0代表第一个DTU位置;

pModemInfo:指向用以保存DTU信息的数据结构;

返回:成功返回TRUE,失败返回FALSE

说明:如果失败了,可以调用DSGetLastError()函数查看错误原因。

一般来说DSGetDtuCount()和DSGetDtuByPosition()函数配合使用,用以查看当前所有DTU的信息,如下例所示:

u32t uiDtuCount;

uiDtuCount=DSGetDtuCount();

DtuInfoStruct dtuInfo;

u32t i;

for(i=0;i<uiDtuCount;i++)

{

DSGetDtuByPosition(i,&dtuInfo);

//对dtuInfo进行操作

}

8) voidDSGetLastError(char*str,intnMaxBufSize);

功能:获得先前API执行时发生的错误;

参数:str:用来存放错误信息的缓冲区;

nMaxStrSize:缓冲区的最大长度,如果错误信息的大小超过了这个值,则此函数将把错误信息的尾部截除。

返回:无

9) BOOLDSDisconnect(u32tmodemId);

功能:断开指定ID号的DTU连接

参数:modemId:DTU的ID号,用以标识一个DTU

返回:成功返回TRUE,失败返回FALSE

说明:如果失败了,可以调用DSGetLastError()函数查看错误原因。

4、函数的具体使用

3) 导入动态库

调用WINDOWSAPI函数LoadLibrary装载动态库,如下:

HMODULE DllMule; //指向动态库的句柄

BOOL(*DSStartService)(u16t); //定义一个指向函数的地址的指针

hDllMole=LoadLibrary(“gprsdll.dll”);

If(hDllMole!=NULL) //判断调用是否成功

{

//从动态库中取函数地址

DSStartService=GetProcAddress(hDllMole,”DSStartService”);

if(DSStartService!=NULL) //判断是否取到该函数地址

{

if((*DSStartService)(5001)!=FALSE)

MessageBox(“启动成功”);

Else

MessageBox(“启动失败”);

}

}

在程序开始时需要调用动态库,程序运行完毕后,要释放动态库,调用windowsAPI函数FreeLibrary可释放动态库:

FreeLibrary(hDllMole);//TRUE-successFALSE-failed

程序中LoadLibrary次数必须和FreeLibrary相同,每调用一次LoadLibrary,相应的应该调用一次FreeLibrary,保证每次调用后都会释放。

4) 启动服务

首先从动态库中取到该函数地址,取到地址后,就可以执行该函数,如下:

BOOL(*DSStartService)(u16t); //定义一个指向函数的地址的指针

DSStartService=(BOOL(*)(u16t))GetProcAddress(hDllMole,“DSStartService”);

if(DSStartService!=NULL)

{

(*DSStartService)(5001);

}

5) 停止服务

BOOL(*DSStopService)(void);

DSStopService=(BOOL(*)(void))GetProcAddress(hDllMole,“DSStopService”);

If(DSStopService!=NULL)

(*DSStopService)();

6) 读数据

BOOLDSGetNextData(ModemDataStruct*,u16t);

DSGetNextData=

(BOOL(*)(ModemDataStruct*,u16t))GetProcAddress(hDllMole,“DSGetNextData”);

if(DSGetNextData!=Null)

if((*DSGetNextData)(&dtudata,100)==0) //dtudata为DtuDataStruct型结构

//如果没有数据最长等待100秒

{

//处理结构dtudata中的数据

}

7) 发送数据

BOOLDSSendData(u32t,u16t,u8t*);

DSSendData=(BOOL(*)(u32t,u16t,u8t*))GetProcAddress(hDllMole,“DSSendData”);

if(DSSendData!=NULL)

{

(*DSSendData)(nID,len,buf);

}

8) 用户列表

底层服务维护一张用户列表,记录当前在线用户的信息,DSC如果想知道底层用户列表,需要调用提供的API函数:DSGetModemCount、DSGetModemByPosition

for(u32ti=0;i<(*DSGetModemCount)();i++)

{

(*DSGetModemByPosition)(i,&dtuinfo);

//1、处理记录用户信息记录dtuinfo中的信息;

}

9) 错误信息

可以通过调用DSGetLastError()函数来获得上次调用API函数失败后的具体的错误信息。

charszErrorMsg[256];

DSGetLastError(szErrorMsg,255);

这个是厦门才茂DTU动态库文件,如果需要咨询更详细,可以直接联系厦门才茂技术,或者直接到他们网站咨询

❸ 有数据,需要通过PC机,用rs485采集,然后存到SQL数据库中。 不太懂这个过程要怎么实现,求大

串口读写,设置好设备与PC的相关串口参数,PC机向设备发送通信命令,设备返回相关信息,跟据数据设定拆分出你所需的数据写入SQL数据库即可

❹ ABPLC如何采集读写MYSQL数据库

通过数据库网关连接罗克韦尔1756-L72的以太网端口标签方式采集数据,将数据存入MySQL数据库,以下描述具体的操作步骤。PLC数据MQTT多主题发布/订阅西门子PLC数据采集到数据库

网关模块安装在设备侧,不用电脑软件,随设备上电启动自动运行,保证设备数据采集与设备运行同步,简单高效的完成了数据采集;已批量用于多种行业的智能工厂,大大提高MES等工业互联网项目的实施效率。IGT-DSER带有两种数据缓存功能:

1. 高频次采集数据缓存,打包后一次性上报到数据库;

2. 断网、服务器维护上报异常时,将数据缓存,待故障解除后重新上报到数据库

网关支持西门子、三菱、欧姆龙、施耐德等几乎所有的PLC品牌,通过以上参数软件自行切换即可;关于网关模块的详细介绍可查看CSDN的这篇文章,或者到这里下载PDF手册。以下是详细的操作步骤:


首先用Navicat连接服务器数据库,建立一个数据表,名称为'abplcdata',数据表设计视图如下:

然后在PC上运行网关的参数设置软件,网线连接IGT-DSER网关的网口1,先配置网络参数(默认IP:192.168.1.244,确认PC的网口与网关默认IP同网段),通过‘工具’->‘搜索在线网关’,搜索到网关后,修改IP地址等参数,具体如下:


网口1.PLC设备末段IP设置为0表示有多台同系列同网段的PLC,每台PLC的IP地址在PLC数据地址表里面配置,后面有描述;设置完成后通过‘参数’->‘参数写入到网关’,下载参数,会有以下提示:

点‘是(Y)’即可,参数下载成功后将网关断电,网口1接入PLC的交换机网络,同时修改PC的网口参数为PLC同网段,重新搜索网关读取参数后,通过‘功能’->‘数据上报与下载’进入数据服务配置页面,选择SQL远程数据库,配置数据库地址、PLC标签的参数;


配置完成后要下载参数,通过‘工具’->‘重启网关’,重启后,网关即进入工作状态,通过读取参数可查看网关的实际数据,双击配置表对应的数据序号可查看数据值,如下图:

序号001是日期时间,取自网关的RTC时钟;002和003是PLC的控制器二维数组;004、005和006是控制器一维数组;007为程序变量,字符串类型;008是程序数组;009是控制器变量,BOOL类型;

设备/站号栏目的数值9,表示PLC的IP地址(192.168.0.9)末段(前三段与网关的网口1相同),如果需要增加另外的同系列同网段PLC,在这里设置对应的IP末段地址即可,不同的PLC对应不同的数据表,或者不同的记录行;

需要注意配置表‘数据地址’栏是PLC的数据标签,不能错误,否则读不到数据,所以最好是通过PLC的编程软件从PLC导出CSV文件,然后复制到配置表,如下图:

再打开Navicat查看数据库中的数据,如下图:

这样就完成了数据采集,没间隔5秒网关会自动上报一次数据,这个周期可以调整,也可以设置成触发模式,根据数据变化上报数据;

相关资源:利用PLC实现数据采集_plc数据采集并存入数据库,plc数据采集-专业...

————————————————

版权声明:本文为CSDN博主“肉褚”的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/weixin_42302872/article/details/113655413

❺ 西门子PLC1200数据如何直接存储到SQL数据库中

网上搜到的:
pc从西门子plc读取数据的方法有两类:

1是通过wincc这类组态软件

2是自己用高级语言(vb、vc等等),方法主要有:
opc(西门子simaticnet opc、第三方kepware opc)
prodave(西门子的一个软件包,提高vb和c的通讯函数库)
simticnet软件提供了几个通讯dll(此法是一般的第三方scada所采用)

可以用其他组态软件,比如组态王。也可以用vb编写一程序然后从plc读取数据再写入数据库。如果不需要监控画面,我觉得vb好些。