Delphi技术实现串口数据库监控 (delphi 监控串口数据库)

Delphi技术是一种优秀的软件开发工具,用于开发企业级应用程序。在许多行业中,特别是生产制造业和工业生产领域,大量的设备需要与计算机进行通信,并在数据库中存储和分析数据。因此,在这些行业中,对串口的监控往往是非常关键的。在这篇文章中,我们将通过。

之一步:连接串口

连接串口是实现串口数据库监控的关键步骤。在 Delphi 中,我们可以通过使用TComPort组件来实现串口的连接。TComPort组件能够帮助我们方便地完成串口的数据读取和写入。对于需要通信的串口设备,通常会有厂家提供的通信协议文档,这个文档中包含了串口通信协议的格式和交换协议,可以通过这个文档来了解设备的通信协议,并设置好串口连接的参数。

通过以下代码实现串口连接:

“`

ComPort1.Port := ‘COM14’;

ComPort1.BaudRate := 9600;

ComPort1.DataBits := dbEight;

ComPort1.Parity.Bits := prNone;

ComPort1.StopBits := One;

ComPort1.Open;

“`

在上面的代码中,我们设置了串口的参数,然后通过“ComPort1.Open”方法打开了串口。这时,我们就已经成功连接了串口。

第二步:读取串口数据

接下来,我们需要从串口中读取数据并将其存储到数据库中。在 Delphi 中,我们可以使用DataSet组件来存储从串口读取的数据。DataSet 是用于存储数据的通用数据结构,可以将从串口读取的数据存储到 DataSet 中。

通过以下代码实现从串口中读取数据:

“`

procedure TForm1.ComPort1RxChar(Sender: TObject; Count: Integer);

begin

DataSet1.Append;

DataSet1.FieldByName(‘Data’).AsString := ComPort1.ReadStr(Count);

DataSet1.Post;

end;

“`

在这个代码中,我们在TComPort对象上设置了一个“ComPort1RxChar”事件。每当串口收到数据时,这个事件就会被激发。在这个事件中,我们使用DataSet组件把数据存储到数据库中。在这个例子中,我们创建了一个名为“Data”的字段,并将收到的数据存储到这个字段中。

第三步:打开数据库

在 Delphi 中,我们可以使用TADOConnection组件连接数据库。TADOConnection 可以帮助我们连接多种类型的数据库,包括 Microsoft Access、Microsoft SQL Server、Oracle 等。连接数据库之后,我们可以使用DataSet对象的LoadFromDataSet或者SaveToDatabase方法把数据保存到数据库中。

通过以下代码实现打开数据库:

“`

const

connString = ‘Provider=SQLOLEDB;Data Source=.\SQLEXPRESS;Initial Catalog=mydatabase;Integrated Security=True’;

procedure TForm1.FormCreate(Sender: TObject);

begin

ADOConnection1.ConnectionString := connString;

ADOConnection1.Connected := True;

end;

procedure TForm1.Button1Click(Sender: TObject);

begin

DataSet1.LoadFromDataSet(ADOQuery1);

DataSet1.Open;

end;

procedure TForm1.Button2Click(Sender: TObject);

begin

DataSet1.SaveToDatabase(ADOQuery1);

end;

“`

在这个代码中,我们首先使用“const connString”定义了连接字符串。然后在“FormCreate”事件中,我们设置了ADOConnection对象的连接字符串,并且连接到数据库。在按钮点击事件中,我们可以使用LoadFromDataSet 或者 SaveToDatabase方法把数据保存到数据库中。

通过这三个步骤,我们就实现了使用 Delphi 技术来监控串口,并把数据存储到数据库中的功能。这个例子可以扩展到更多的设备和应用领域,为工业生产和制造业带来更便捷的管理和监控方式。

相关问题拓展阅读:

delphi如何读取串口(com)

使用com控件可很方便的解决此问题。

Delphi是一种具有功能强大、简便易用和代码执行速度快等优点的可视化快速应用开发工具,它在构架企业信息系统方面发挥着越来越重要的作用,许多程序员愿意选择 Delphi作为开发工具编制各种应用程序。但是,美中不足之处是 Delphi没有自带的串口通信控件,在它的帮助文档里也没有提及串口通信,这就给编制通信程序的开发人员带来许多不便。

目前,利用 Delphi实现串口通信的常用的方法有 3种:一是利用控件,如 MSCOMM控件和 SPCOMM控件;二是使用 API函数;三是调用其他串口通信程序。其中利用 API编写串口通信程序较为复杂,需要掌握大量的通信知识。相比较而言,利用 SPCOMM控件则相对较简单,并且该控件具有丰富的与串口通信密切相关的属性及事件,提供了对串口的各种操作,而且还支持多线程。下面本文结合实例详细介绍 SPCOMM控件的使用。

SPCOMM的安装

1.选择下拉菜单 Component中的 Install Component选项,弹出如图 1所示的窗口。

图 1

在 Unit file name处填写 SPCOMM控件所在的路径,其他各项可用默认值,点击 OK按钮。

2.安装后,在 System控件面板中将出现一个红色控件 COM。现在就可以像 Delphi自带控件一样使用 COM控件了。

SPCOMM的属性、方法和事件

1.属性

●CommName:表示 COM1、 COM2等串口的名字;

●BaudRate:根据实际需要设定的波特率,在串口打开后也可更改此值,实际波特率随之更改;

●ParityCheck:表示是否需要奇偶校验;

●ByteSize:根据实际情况设定的字节长度;

●Parity:奇偶校验位;

●StopBits:停止位;

●SendDataEmpty:这是一个布尔型属性,为 true时表示发送缓存为空,或者发送队列里没有信息;为 false时表示发送缓存不为空,或者发送辩腊队列里有信息。

2.方法

●Startcomm方法用于打开串口,当打开失败时通常会报错。错误主要有 7种:⑴串口已经打开;⑵打开串口错误;⑶文件句柄不是通信句柄;⑷不能够安装通信缓存;⑸不能产生事件;⑹不能产生读进程;⑺不能产生写进程;

●StopComm方法用于关闭串口,没有返回值;

●WriteCommData(pDataToWrite: PChar;dwSizeofDataToWrite:Word )方法是个带有布尔型返回值的函数,用于将一个字符串发送到写进程,发送成功返回 true,发送失败返回 false。执行此函数将立即得到返回值,发送操作随后执行。该函数有两个参数,其中 pDataToWrite是要发送的字符串, dwSizeofDataToWrite是发送字符串的长度。

3.事件

●OnReceiveData :procedure (Sender: TObject;Buffer: Pointer;BufferLength: Word) of object

当有数据输入缓存时将触发该事件,在这里可以对从串口收到的数据进行处理。 Buffer中是收到的数据, BufferLength是收到的数据长度。

●OnReceiveError : procedure(Sender: TObject; EventMask : DWORD)

当接收数据出现错误时将触发该事件。

SPCOMM的使用

下面是一个利用携孙滑 SPCOMM控件的串口通信的例子。

以实现 PC机与单片机 8051之间的通信为例,首先要调通它们之间的握手信号。假凯孙定它们之间的通信协议是: PC到 8051一帧数据 6个字节, 8051到 PC一帧数据也为 6个字节。当 PC发出( F0,01,FF,FF,01,F0)后 8051能收到一帧( F0,01,FF,FF,01,F0),表示数据通信握手成功,两者之间就可以按照协议相互传输数据。

创建一个新的工程 COMM.DPR,把窗体的 NAME属性定为 FCOMM,把窗体的标题定义为测试通信,按照图 2添加控件 (图 2中黑色矩形围住的控件即为 COMM1)。

图 2

1.设定 COMM1属性:

●波特率: 4800;

●奇偶校验位:无;

●字节长度: 8;

●停止位: 1;

●串口: COM1。

Memo1中将显示发送和接收的数据。将新的窗体存储为 Comm.pas。

2.编写源代码

//变量说明

var

fcomm: TFCOMM;

viewstring:string;

i:integer;

rbuf,uf:array of byte;

//打开串口

procedure TFCOMM.FormShow(Sender: TObject);

begin

comm1.StartComm;

end;

//关闭串口

procedure TFCOMM.FormClose(Sender: TObject; var Action: TCloseAction);

begin

comm1.StopComm;

end;

//自定义发送数据过程

procedure senddata;

var

i:integer;

comm:boolean;

begin

viewstring:=‘’ ;

comm:=true;

for i:=1 to 6 do

begin

if not fcomm.comm1.writecommdata(@uf,1) then

begin

comm:=false;

break;

end;

//发送时字节间的延时

sleep(2);

viewstring:=viewstring+ inttohex(uf,2)+‘’ ; end;

viewstring:=‘发送’+ viewstring;

fcomm.memo1.lines.add(viewstring);

fcomm.memo1.lines.add(‘’ );

if not comm then messagedlg(‘发送失败 !’ ,mterror,,0);

end;

//发送按钮的点击事件

procedure TFCOMM.Btn_sendClick(Sender: TObject);

begin

uf:=byte($ f0); //帧头

uf:=byte($ 01); //命令号

uf:=byte($ ff);

uf:=byte($ ff);

uf:=byte($ 01);

uf:=byte($ f0); //帧尾

senddata;//调用发送函数

end;

//接收过程

procedure TFCOMM.Comm1ReceiveData(Sender: TObject; Buffer: Pointer;BufferLength: Word);

var

i:integer;

begin

viewstring:=‘’ ;

move(buffer^,pchar(@rbuf^),bufferlength);

for i:=1 to bufferlength do

viewstring:=viewstring+ inttohex(rbuf,2)+‘’ ;

viewstring:=‘接收’+ viewstring;

memo1.lines.add(viewstring);

memo1.lines.add(‘’ );

关于delphi 监控串口数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Delphi技术实现串口数据库监控 (delphi 监控串口数据库)