Qt TCP/IP 数据存储部分

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编号、开始时间、结束时间以及数据;

  1. 在数据库里创建一个表
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();
}
  1. 将数据存放在数据库的表中
//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!"));
}
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值