QSqlQuery的execBatch方法准实时写oracle数据库

该示例展示了一个接收线程如何处理至少200包/秒的数据,将其写入29张表。通过创建三个并发线程,确保了至少600包/秒的数据包频率,且不丢包,延迟不超过3秒。重点使用QSqlQuery的execBatch方法进行批处理,将数据插入到表table1和table2。
摘要由CSDN通过智能技术生成

 

在这个实例中创建一个接收线程,同时启动三个任务,每个任务对应一个准实时写数据库线程,数据需要写入29张表中,每个任务的数据包频率不小于200包/秒,对于接收线程来说数据包频率达到不小于600包/秒,经过上百此测试显示不会丢一个包,延时不超过3秒,以下代码只贴出了重要部分代码,数据库表只示意性地写了两张表。

1、首先在全局头文件中创建数据结构:

typedef struct _DB_DATA_BUFFER{

struct timeval tv_RecvTime;

UINT32 DataLen;

unsigned char* Data;

}DB_DATA_BUFFER,*PDB_DATA_BUFFER;

2、创建接收线程:

#include "l_global.h"

extern PGLOBAL_DATA pGlobalData;

extern SIGLIST mSIGLIST[TASK_MAX];

void* DataRecvThread(void* UNUSED(arg))

{

int result;

char RecvBuffer[65536];

struct timeval tv_CurrentTime;

int DataLen;

int TaskIndex;

PINT_PACKET pIntPacket;

pIntPacket = (PINT_PACKET)RecvBuffer;

gettimeofday(&tv_CurrentTime,NULL);

std::map<int,int>::iterator iterTaskMap;

while(!pGlobalData->bExit)

{

//receive data from udp net

result = recvfrom(sock[0], RecvBuffer, 65536, 0, (struct sockaddr*)&m_src_addr, &len);

//*************************************************

pGlobalData->LockFormapTaskId.lock();

iterTaskMap = pGlob

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值