Qt TCP/IP 数据存储部分
(1)对于数据的存储操作,首先得确保接收到了数据,接收客户端需先监听任何有可能向其发送数据的发送客户端,使接受客户端处于等待状态,通过接受客户端与发送客户端的交互确定是否已连接成功,若连接成功,即可进行从机向主机的数据发送操作;
//listen
if(mTcpServer->listen(QHostAddress::Any,1))//判断监听是否成功
{
ui->label_8->setText(tr("Listen Successfully!"));
connect(mTcpServer,SIGNAL(newConnection()),this,SLOT(ConEvent()));
}
else//若不成功
{
ui->label_8->setText(tr("Listen failed!"));
}
(2)主机接收数据时同样得注意数据格式问题,确保接受的数据不会出错。同从机发送的数据格式保持一致,首先接收RTU编号,接着是接收数据的起始时间以及结束时间,然后是接收100个数据;
in>>RTU_NO; //接收RTU编号
in>>TimeStartLabel; //接收起始时间
in>>TimeEndLabel; //接收结束时间
in>>temp; //接收数据
NetData=temp; //数据为通过网络接收到的数据
ReData=temp.split(","); //逗号区分数据
for (int i=0;i<100;i++)
x[i]=ReData.at(i).toDouble();
line->curve(x,100); //将数据反映成图线形式
(3)主机成功接收数据后将数据存储在数据库里。对数据库进行操作前首先得打开数据库,在数据库里新建表用以存放数据,表的内容包括RTU编号、开始时间、结束时间以及数据;
- 在数据库里创建一个表
char sql_cmd[500];
sprintf(sql_cmd,"CREATE TABLE RTU(num INTEGER PRIMARY KEY identity(1,1),"
"RtuName VARCHAR(50) NOT NULL,"
"TimeLabelStart VARCHAR(50) NOT NULL,"
"TimeLabelEnd VARCHAR(50) NOT NULL,"
"Data text NOT NULL)");
QSqlQuery *sqlQuery=new QSqlQuery(db);
if(!sqlQuery->exec(sql_cmd))
{
qDebug()<<sqlQuery->lastError().text();
}
sprintf(sql_cmd,"CREATE CLUSTERED INDEX RTU_idx ON RTU (TimeLabelStart)");
if(!sqlQuery->exec(sql_cmd))
{
qDebug()<<sqlQuery->lastError().text();
}
- 将数据存放在数据库的表中
//insert
QString command = QString("INSERT INTO RTU(RtuName,TimeLabelStart,TimeLabelEnd,Data)"
" VALUES('%1','%2','%3','%4')")
.arg(RTU_NO).arg(TimeStartLabel)
.arg(TimeEndLabel).arg(NetData);
//将数据的RTU编号、开始及结束时间、数据分别插入表中
QSqlQuery *sqlQuery=new QSqlQuery(db);
//判断数据是否成功的存入数据库的表中
if(!sqlQuery->exec(command))
{
ui->label_8->setText(tr("data insert failed!"));
}
else
{
ui->label_8->setText(tr("data insert successfully!"));
}