1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203 |
- #include "db_syncthread.h"
- #include "ytservicecore.h"
- #include <time.h>
- #include <openssl/md5.h>
- #include <string.h>
- //void chkmd5(const char *data, char *md5){
- // MD5_CTX ctx;
- // unsigned char tmp,md[16];
- // int i;
- // MD5_Init(&ctx);
- // MD5_Update(&ctx,data,strlen(data));
- // MD5_Final(md,&ctx);
- // for(i=0;i<16;i++){
- // tmp = (md[i]>>4)&0x0f;
- // if(tmp<10)
- // md5[i*2+0] = (char)(tmp+0x30);
- // else
- // md5[i*2+0] = (char)(tmp+0x37);
- // tmp = md[i]&0x0f;
- // if(tmp<10)
- // md5[i*2+1] = (char)(tmp+0x30);
- // else
- // md5[i*2+1] = (char)(tmp+0x37);
- // }
- // md5[32] = 0x00;
- //}
- bool compareAlarmSet(const AlarmSet &a1, const AlarmSet &a2)
- {
- if(a1.AlarmTime>a2.AlarmTime)
- return true;
- return false;
- }
- DB_SyncThread::DB_SyncThread(QObject *parent) :
- QThread(parent)
- {
- isWorking = false;
- deviceDataList.clear();
- day = 255;
- initTime = true;
- ProgramConf *conf = new ProgramConf(this);
- mdb = QSqlDatabase::addDatabase(conf->getDbDrive(),conf->getDbConnectName());
- mdb.setDatabaseName(conf->getDbName());
- mdb.setHostName(conf->getDbHost());
- mdb.setPort(conf->getDbPort());
- mdb.setUserName(conf->getDbUser());
- mdb.setPassword(conf->getDbPassword());
- mdbOpened = mdb.open();
- }
- bool DB_SyncThread::userInfoSync(QString devid,QString deviceCode, uint sync_id,QString tbname,QDate chkday,uint ID, QString companyCode)
- {
- QString qrysql,sql;
- QString upsql_0="select 1;",upsql_1="select 1;";
- bool found = false;
- bool updated = false;
- int count=0;
- QSqlQuery qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_hj2017 where device_code='%1' and data1<>'U44' and time<now()").arg(devid));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set alm_count=%1, alm_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_hj2017 where device_code='%1' and data1='U44' and time<now()").arg(devid));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set com_count=%1, com_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- for(int i=0;i<dList.length();i++){
- if(dList.at(i).compare(deviceCode)==0)
- {
- found = true;
- break;
- }
- }
- if(!found){
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','0','','1970-01-01 08:00:00','');").arg(deviceCode));
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','1','','1970-01-01 08:00:00','');").arg(deviceCode));
- dList.append(deviceCode);
- pcList.append(0);
- dList.append(deviceCode);
- pcList.append(1);
- }
- qrysql = QString("select id, data3, data5, time, data2, data4 from `%1` where id> %2 and time>'%3-%4-%5 00:00:00' order by id").arg(tbname).arg(sync_id).arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0'));
- qry2 = mdb.exec(qrysql);
- while(qry2.next()){
- setCompanyAlarmSet(deviceCode, AlarmSet(0xffffffff,"",QString::fromUtf8("%1,%2").arg(qry2.value(4).toString()).arg(qry2.value(5).toString()),1,qry2.value(3).toDateTime().toTime_t(),1));
- updated = true;
- if(count==0)
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(qry2.value(1).isNull()?"0":"1")
- .arg(qry2.value(2).isNull()?"":qry2.value(2).toString()).arg(qry2.value(3).isNull()?"1970-01-01 08:00:00":qry2.value(3).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(4).isNull()?"":qry2.value(4).toString()).arg(qry2.value(5).isNull()?"":qry2.value(5).toString());
- else
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(qry2.value(1).isNull()?"0":"1")
- .arg(qry2.value(2).isNull()?"":qry2.value(2).toString()).arg(qry2.value(3).isNull()?"1970-01-01 08:00:00":qry2.value(3).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(4).isNull()?"":qry2.value(4).toString()).arg(qry2.value(5).isNull()?"":qry2.value(5).toString());
- if(qry2.value(1).isNull())
- upsql_0 = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3 %4', point_name='通信报警',dwtype=%5 where device_id='%6' and point_code='%7';")
- .arg(qry2.value(2).isNull()?"":qry2.value(2).toString()).arg(qry2.value(3).isNull()?"1970-01-01 08:00:00":qry2.value(3).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(4).isNull()?"":qry2.value(4).toString()).arg(qry2.value(5).isNull()?"":qry2.value(5).toString())
- .arg(1).arg(devid).arg("0");
- else
- upsql_1 = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3 %4', point_name='主机报警',dwtype=%5 where device_id='%6' and point_code!='0';")
- .arg(qry2.value(2).isNull()?"":qry2.value(2).toString()).arg(qry2.value(3).isNull()?"1970-01-01 08:00:00":qry2.value(3).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(4).isNull()?"":qry2.value(4).toString()).arg(qry2.value(5).isNull()?"":qry2.value(5).toString())
- .arg(1).arg(devid);
- sync_id = qry2.value(0).toUInt();
- count++;
- if(count>=100){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql_0);
- mdb.exec(upsql_1);
- sql = "";
- count=0;
- }
- }
- if(count>0){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql_0);
- mdb.exec(upsql_1);
- sql = "";
- count=0;
- }
- return updated;
- }
- bool DB_SyncThread::waterInfoSync(QString devid, QString deviceCode, uint sync_id, QString tbname, QDate chkday, uint ID,int dwtype, QString companyCode)
- {
- QString qrysql,sql,upsql;
- int count=0;
- bool updated = false;
- bool found = false;
- QSqlQuery qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_sj2017 where device_code='%1' and data1<>'WP4' and data1<>'LL4' and time<now()").arg(devid));
- // .arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set alm_count=%1, alm_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_sj2017 where device_code='%1' and ( data1='WP4' or data1='LL4' ) and time<now()").arg(devid));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set com_count=%1, com_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- for(int i=0;i<dList.length();i++){
- if(dList.at(i).compare(deviceCode)==0)
- {
- found = true;
- break;
- }
- }
- if(!found){
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','1','','1970-01-01 08:00:00','');").arg(deviceCode));
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','2','','1970-01-01 08:00:00','');").arg(deviceCode));
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','3','','1970-01-01 08:00:00','');").arg(deviceCode));
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','4','','1970-01-01 08:00:00','');").arg(deviceCode));
- dList.append(deviceCode);
- pcList.append(1);
- dList.append(deviceCode);
- pcList.append(2);
- dList.append(deviceCode);
- pcList.append(3);
- dList.append(deviceCode);
- pcList.append(4);
- }
- qrysql = QString("select id, time, data1, data2, data3, data4 from `%1` where id>%2 and time>'%3-%4-01 00:00:00' and time<now() order by id ").arg(tbname).arg(sync_id).arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0'));
- qry2 = mdb.exec(qrysql);
- while(qry2.next()){
- QString dat1 = qry2.value(2).toString();
- setCompanyAlarmSet(deviceCode, AlarmSet(0xffffffff,"",
- QString::fromUtf8("%1,%2").arg(QString::compare(dat1,"WP1")==0?QString::fromUtf8("低压"):
- (QString::compare(dat1,"WP2")==0?QString::fromUtf8("高压"):
- (QString::compare(dat1,"WP3")==0?QString::fromUtf8("故障"):
- (QString::compare(dat1,"WP4")==0?QString::fromUtf8("离线"):
- (QString::compare(dat1,"WP0")==0?QString::fromUtf8("恢复"):
- (QString::compare(dat1,"LL1")==0?QString::fromUtf8("低液位"):
- (QString::compare(dat1,"LL2")==0?QString::fromUtf8("高液位"):
- (QString::compare(dat1,"LL3")==0?QString::fromUtf8("故障"):
- (QString::compare(dat1,"LL4")==0?QString::fromUtf8("离线"):
- (QString::compare(dat1,"LL0")==0?QString::fromUtf8("恢复"):"")))))))))).arg(qry2.value(5).toString()),
- 2,qry2.value(1).toDateTime().toTime_t(),1));
- updated = true;
- if(count==0){
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(1).arg(qry2.value(2).isNull()?"0":qry2.value(2).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(2).arg(qry2.value(3).isNull()?"0":qry2.value(3).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(3).arg(qry2.value(4).isNull()?"0":qry2.value(4).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(4).arg(qry2.value(5).isNull()?"0":qry2.value(5).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- }else{
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(1).arg(qry2.value(2).isNull()?"0":qry2.value(2).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(2).arg(qry2.value(3).isNull()?"0":qry2.value(3).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(3).arg(qry2.value(4).isNull()?"0":qry2.value(4).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(4).arg(qry2.value(5).isNull()?"0":qry2.value(5).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss")).arg("");
- }
- QString wp = qry2.value(2).toString();
- if(wp.compare("WP0")==0)
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='状态',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(0)
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg(QString::fromUtf8("正常")).arg(dwtype).arg(devid).arg(1);
- else if(wp.compare("WP1")==0)
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='状态',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(1)
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg(QString::fromUtf8("低压")).arg(dwtype).arg(devid).arg(1);
- else if(wp.compare("WP2")==0)
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='状态',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(2)
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg(QString::fromUtf8("高压")).arg(dwtype).arg(devid).arg(1);
- else if(wp.compare("WP3")==0)
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='状态',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(3)
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg(QString::fromUtf8("故障")).arg(dwtype).arg(devid).arg(1);
- else if(wp.compare("WP4")==0)
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='状态',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(4)
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg(QString::fromUtf8("离线")).arg(dwtype).arg(devid).arg(1);
- upsql.append(QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='剩余电量',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(qry2.value(3).isNull()?"0":qry2.value(3).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg("").arg(dwtype).arg(devid).arg(2));
- upsql.append(QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='无线信号',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(qry2.value(4).isNull()?"0":qry2.value(4).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg("").arg(dwtype).arg(devid).arg(3));
- upsql.append(QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='水压/水位',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(qry2.value(5).isNull()?"0":qry2.value(5).toString())
- .arg(qry2.value(1).isNull()?"1970-01-01 08:00:00":qry2.value(1).toDateTime().toString("yyyy-MM_dd HH:mm:ss"))
- .arg("").arg(dwtype).arg(devid).arg(4));
- count += 4;
- sync_id = qry2.value(0).toUInt();
- if(count>=100){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql);
- count=0;
- sql="";
- }
- }
- if(count>0){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql);
- count=0;
- sql="";
- }
- return updated;
- }
- bool DB_SyncThread::smokerInfoSync(QString devid, QString deviceCode, uint sync_id, QString tbname, QDate chkday, uint ID, QString companyCode)
- {
- QString qrysql,sql,upsql;
- int count=0;
- bool found = false;
- bool updated = false;
- for(int i=0;i<dList.length();i++){
- if(dList.at(i).compare(deviceCode)==0)
- {
- found = true;
- count++;
- // break;
- }
- }
- if(!found){
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','1','','1970-01-01 08:00:00','');").arg(deviceCode));
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','2','','1970-01-01 08:00:00','');").arg(deviceCode));
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','3','','1970-01-01 08:00:00','');").arg(deviceCode));
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','4','','1970-01-01 08:00:00','');").arg(deviceCode));
- dList.append(deviceCode);
- pcList.append(1);
- dList.append(deviceCode);
- pcList.append(2);
- dList.append(deviceCode);
- pcList.append(3);
- dList.append(deviceCode);
- pcList.append(4);
- }else if(count==3){
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','4','','1970-01-01 08:00:00','');").arg(deviceCode));
- dList.append(deviceCode);
- pcList.append(4);
- }
- count=0;
- QSqlQuery qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_hj2017 where device_code='%1' and data1<>'U44' and time<now()").arg(devid));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set alm_count=%1, alm_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- qrysql = QString("select id, DeviceStatus, BatteryLevel, SensorLevel, storeTime,TData from %1 where id>%2 and storeTime>'%3-%4-01 00:00:00' and storeTime<now() and DeviceType=1")
- .arg(tbname).arg(sync_id).arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0'));
- qry2 = mdb.exec(qrysql);
- while(qry2.next()){
- updated = true;
- int sta = qry2.value(1).toInt();
- if(count==0){
- sql = QString::fromUtf8("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(1).arg(qry2.value(1).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(sta==1?QString::fromUtf8("报警")
- :(sta==2?QString::fromUtf8("报警静音")
- :(sta==4?QString::fromUtf8("低压")
- :(sta==5?QString::fromUtf8("故障")
- :(sta==7?QString::fromUtf8("正常")
- :"")))));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(2).arg(qry2.value(2).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(3).arg(qry2.value(3).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("");
- if(qry2.value(5).toString().compare("-")!=0){
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(4).arg(qry2.value(5).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("");
- }
- }else{
- sql += QString::fromUtf8(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(1).arg(qry2.value(1).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(sta==1?QString::fromUtf8("报警")
- :(sta==2?QString::fromUtf8("报警静音")
- :(sta==4?QString::fromUtf8("低压")
- :(sta==5?QString::fromUtf8("故障")
- :(sta==7?QString::fromUtf8("正常")
- :"")))));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(2).arg(qry2.value(2).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("");
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(3).arg(qry2.value(3).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("");
- if(qry2.value(5).toString().compare("-")!=0){
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(4).arg(qry2.value(5).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("");
- }
- }
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='状态',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(sta==7?0:sta)
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(sta==1?QString::fromUtf8("报警")
- :(sta==2?QString::fromUtf8("报警静音")
- :(sta==4?QString::fromUtf8("低压")
- :(sta==5?QString::fromUtf8("故障")
- :(sta==7?QString::fromUtf8("正常")
- :"")))))
- .arg(3).arg(devid).arg(1);
- upsql.append(QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='剩余电量',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(qry2.value(2).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("").arg(3).arg(devid).arg(2));
- upsql.append(QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='无线信号',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(qry2.value(3).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("").arg(3).arg(devid).arg(3));
- if(qry2.value(5).toString().compare("-")!=0){
- upsql.append(QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3', point_name='温度',dwtype=%4 where device_id='%5' and point_code='%6';")
- .arg(qry2.value(5).toString())
- .arg(qry2.value(4).isNull()?"1970-01-01 08:00:00":qry2.value(4).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg("").arg(6).arg(devid).arg(4));
- }
- count += 3;
- sync_id = qry2.value(0).toUInt();
- if(count>=100){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql);
- count=0;
- sql="";
- }
- }
- if(count>0){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql);
- count=0;
- sql="";
- }
- return updated;
- }
- bool DB_SyncThread::rtuInfoSync(QString devid, QString deviceCode, uint sync_id, QString tbname, QDate chkday, uint ID, QString companyCode)
- {
- QString qrysql,sql,upsql="";
- int count=0;
- bool found = false;
- bool updated= false;
- QSqlQuery qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_rtu2017 where device_code='%1' and status<>'44' and time<now()").arg(devid));
- // .arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set alm_count=%1, alm_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_rtu2017 where device_code='%1' and status='44' and time<now()").arg(devid));
- // .arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')));;
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set com_count=%1, com_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- found = false;
- for(int i=0;i<dList.length();i++){
- if(dList.at(i).compare(deviceCode)==0){
- found = true;
- break;
- }
- }
- if(!found){
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','','%2','','1970-01-01 08:00:00','');").arg(deviceCode).arg(0));
- dList.append(deviceCode);
- pcList.append(0);
- }
- qrysql = QString("select id, status, port, ncmd, data3, data2, data4, time, data1 from %1 where id>%2 and time>'%3-%4-%5 00:00:00' and time<now()")
- .arg(tbname).arg(sync_id).arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0'));
- qry2 = mdb.exec(qrysql);
- QSqlQuery qry3 = mdb.exec(QString("select iotype,ports,ioname,systypeup from sp_owner_port where owner_code='%1'").arg(devid));
- QStringList nameList,vonameList;
- QList<int> typeList,portList;
- while(qry3.next()){
- typeList.append(qry3.value(0).toInt());
- portList.append(qry3.value(1).toInt());
- nameList.append(qry3.value(2).toString());
- vonameList.append(qry3.value(3).toString());
- found = false;
- if(qry3.value(0).toInt()==1){
- for(int i=0;i<dList.length();i++){
- if(dList.at(i).compare(deviceCode)==0){
- if(pcList.at(i)==qry3.value(1).toInt()){
- found = true;
- break;
- }
- }
- }
- if(found)
- mdb.exec(QString("update sp_owner_status set point_name='%1',dwtype=6 where device_id='%2' and point_code='%3'")
- .arg(qry3.value(2).toString()).arg(devid).arg(qry3.value(1).toInt()));
- else{
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','%2','%3','','1970-01-01 08:00:00','');").arg(deviceCode).arg(qry3.value(2).toString()).arg(qry3.value(1).toInt()));
- dList.append(deviceCode);
- pcList.append(qry3.value(1).toInt());
- }
- }else{
- for(int i=0;i<dList.length();i++){
- if(dList.at(i).compare(deviceCode)==0){
- if(pcList.at(i)==(qry3.value(1).toInt()+64)){
- found = true;
- break;
- }
- }
- }
- if(found)
- mdb.exec(QString("update sp_owner_status set point_name='%1',dwtype=6 where device_id='%2' and point_code='%3'")
- .arg(qry3.value(2).toString()).arg(devid).arg(qry3.value(1).toInt()+64));
- else{
- mdb.exec(QString("insert into sp_owner_status (id,device_id,point_name,point_code,point_data,data_time,content) values (NULL,'%1','%2','%3','','1970-01-01 08:00:00','');").arg(deviceCode).arg(qry3.value(2).toString()).arg(qry3.value(1).toInt()+64));
- dList.append(deviceCode);
- pcList.append(qry3.value(1).toInt()+64);
- }
- }
- }
- qry3.clear();
- while(qry2.next()){
- updated = true;
- if(qry2.value(1).toString().compare("44")==0)
- {
- if(count==0)
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(0).arg(1).arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString());
- else
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(0).arg(1).arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString());
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3 %4', point_name='通信报警',dwtype=%5 where device_id='%6' and point_code='%7';")
- .arg(0).arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString()).arg(6).arg(devid).arg(0);
- mdb.exec(upsql);
- }else{
- setCompanyAlarmSet(deviceCode, AlarmSet(0xffffffff,"",QString::fromUtf8("%1,%2").arg(qry2.value(5).toString()).arg(qry2.value(6).toString()),6,qry2.value(7).toDateTime().toTime_t(),1));
- upsql = QString::fromUtf8("update sp_owner_status set point_data='',content='' where device_id='%1' and point_code='0'").arg(devid);
- mdb.exec(upsql);
- if(!qry2.value(2).isNull()){
- if(qry2.value(2).toString().compare("E3")==0){
- int tmpIdx = qry2.value(3).toString().toInt(nullptr,16);
- if(tmpIdx>0){
- QString pv = "0";
- QString pname = "", vname="";
- for(int Idx=0;Idx<vonameList.length();Idx++){
- if((typeList.at(Idx)==1)&&(portList.at(Idx)==tmpIdx)){
- pname = nameList.at(Idx);
- vname = vonameList.at(Idx);
- break;
- }
- }
- if((vname.compare(QString::fromUtf8("故障"))==0)
- ||(vname.compare(QString::fromUtf8("手动"))==0)
- ||(vname.compare(QString::fromUtf8("运行"))==0)
- ||(vname.compare(QString::fromUtf8("接线"))==0)
- ||(vname.compare(QString::fromUtf8("正常"))==0)){
- if(qry2.value(1).toInt()==0)
- pv="0";
- else
- pv="1";
- }else{
- if(qry2.value(1).toInt()==0)
- pv="1";
- else
- pv="0";
- }
- if(count==0)
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(qry2.value(3).toInt()).arg(pv)
- .arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString());
- else
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(qry2.value(3).toInt()).arg(pv)
- .arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString());
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3 %4', point_name='%5',dwtype=%6 where device_id='%7' and point_code='%8';")
- .arg(pv)
- .arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString()).arg(pname)
- .arg(6).arg(devid).arg(tmpIdx);
- mdb.exec(upsql);
- }
- }else if(qry2.value(2).toString().compare("E6")==0){
- if(count==0)
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(qry2.value(3).toInt()+64).arg(qry2.value(8).toString())
- .arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString());
- else
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','%6 %7')")
- .arg(qry2.value(0).toUInt()).arg(devid).arg(qry2.value(3).toInt()+64).arg(qry2.value(8).toString())
- .arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(5).toString()).arg(qry2.value(6).toString());
- int tmpIdx = qry2.value(3).toInt();
- if(tmpIdx>0){
- QString pname = "";
- for(int Idx=0;Idx<nameList.length();Idx++){
- if((typeList.at(Idx)==2)&&(portList.at(Idx)==tmpIdx)){
- pname = nameList.at(Idx);
- break;
- }
- }
- upsql = QString::fromUtf8("update sp_owner_status set point_data='%1', data_time='%2', content='%3 %4 %5',dwtype=%6 where device_id='%7' and point_code='%8';")
- .arg(qry2.value(8).toString())
- .arg(qry2.value(7).isNull()?"1970-01-01 00:00:00":qry2.value(7).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(pname).arg(qry2.value(5).toString())
- .arg(qry2.value(6).toString())
- .arg(6)
- .arg(devid)
- .arg(tmpIdx+64);
- mdb.exec(upsql);
- }
- }
- }
- }
- count++;
- sync_id = qry2.value(0).toUInt();
- if(count>=100){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- // mdb.exec(upsql);
- count=0;
- sql="";
- upsql="";
- }
- }
- if(count>0){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- // mdb.exec(upsql);
- count=0;
- sql="";
- upsql="";
- }
- return updated;
- }
- bool DB_SyncThread::videoalarmSync(QString devid, QString deviceCode, uint sync_id, QString tbname, QDate chkday, uint ID, QString companyCode)
- {
- QString sql,upsql;
- int count=0;
- bool updated = false;
- QString csql = QString("select count(*) as count, sum(clzt) as sum from sp_video2017 where device_code='%1' and time<now()").arg(devid);
- // printf("%s\n",csql.toUtf8().data());
- QSqlQuery qry2 = mdb.exec(csql);
- // .arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')));
- if(qry2.next()){
- csql = QString("update sp_device_sync set alm_count=%1, alm_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid);
- // printf("%s\n",csql.toUtf8().data());
- mdb.exec(csql);
- }
- qry2.clear();
- qry2 =mdb.exec(QString("select count(*) from sp_owner_status where device_id='%1'").arg(devid));
- if(qry2.next()){
- if(qry2.value(0).toInt()==0){
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',16,'占道侦测告警',1,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',16,'火点侦测告警',2,0,'1970-01-01 08:00:00','')").arg(devid));
- }
- }
- qry2.clear();
- // printf("%s\n",QString("select id,port,time from sp_video2017 where id>%1 and time>'%2-%3-%4 00:00:00' and device_code='%5'").arg(sync_id).arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')).arg(devid).toUtf8().data());
- qry2 = mdb.exec(QString("select id,port,time,data4 from sp_video2017 where id>%1 and time>'%2-%3-%4 00:00:00' and time<now() and device_code='%5'").arg(sync_id).arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')).arg(devid));
- while(qry2.next()){
- updated = true;
- // system(QString("echo '%1 %2'>> /root/data.txt").arg(deviceCode).arg(qry2.value(2).toString()).toUtf8().data());
- setCompanyAlarmSet(deviceCode,AlarmSet(0xffffffff,"",qry2.value(3).toString(),16,qry2.value(2).toDateTime().toTime_t(),1));
- if(count==0){
- if(qry2.value(1).toInt()==1){
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5',''),(NULL,%6,'%7','%8','%9','%10','')")
- .arg(qry2.value(0).toInt()).arg(devid).arg(1).arg(1).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(0).toInt()).arg(devid).arg(2).arg(0).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }else{
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5',''),(NULL,%6,'%7','%8','%9','%10','')")
- .arg(qry2.value(0).toInt()).arg(devid).arg(1).arg(0).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(0).toInt()).arg(devid).arg(2).arg(1).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }
- }else{
- if(qry2.value(1).toInt()==1)
- sql += QString(", (NULL,%1,'%2','%3','%4','%5',''),(NULL,%6,'%7','%8','%9','%10','')")
- .arg(qry2.value(0).toInt()).arg(devid).arg(1).arg(1).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(0).toInt()).arg(devid).arg(2).arg(0).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- else
- sql += QString(", (NULL,%1,'%2','%3','%4','%5',''),(NULL,%6,'%7','%8','%9','%10','')")
- .arg(qry2.value(0).toInt()).arg(devid).arg(1).arg(0).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"))
- .arg(qry2.value(0).toInt()).arg(devid).arg(2).arg(1).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }
- if(qry2.value(1).toInt()==1)
- upsql = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='占道侦测告警' where device_id='%3' and point_code=1;")
- .arg(1).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- else
- upsql = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='火点侦测告警' where device_id='%3' and point_code=2;")
- .arg(1).arg(qry2.value(2).isNull()?"1970-01-01 08:00:00":qry2.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- sync_id = qry2.value(0).toUInt();
- count++;
- if(count>=100){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- // printf("%s\n%s",sql.toUtf8().data(),upsql.toUtf8().data());
- mdb.exec(sql);
- mdb.exec(upsql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- count = 0;
- sql="";
- upsql="";
- }
- }
- if(count>0){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- // printf("%s\n%s",sql.toUtf8().data(),upsql.toUtf8().data());
- mdb.exec(sql);
- mdb.exec(upsql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- count = 0;
- sql="";
- upsql="";
- }
- return updated;
- }
- bool DB_SyncThread::efireInfoSync(QString devid, QString deviceCode, uint sync_id, QString tbname, QDate chkday, uint ID, QString companyCode)
- {
- QString upsql1, upsql2, upsql3, upsql4,upsql5,upsql6,sql;
- int count=0;
- bool updated = false;
- QSqlQuery qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_ef2017 where device_code='%1' and data1='EF9' and time<now()").arg(devid));
- // .arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set com_count=%1, com_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- qry2 = mdb.exec(QString("select count(*) as count, sum(clzt) as sum from sp_ef2017 where device_code='%1' and data1<>'EF9' and time<now()").arg(devid));
- // .arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')));
- if(qry2.next()){
- mdb.exec(QString("update sp_device_sync set alm_count=%1, alm_confirm=%2 where device_id='%3'")
- .arg(qry2.value(0).toInt())
- .arg(qry2.value(0).toInt()>0?qry2.value(1).toInt():0)
- .arg(devid));
- }
- qry2.clear();
- qry2 =mdb.exec(QString("select count(*) from sp_owner_status where device_id='%1'").arg(devid));
- if(qry2.next()){
- if(qry2.value(0).toInt()==0){
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'供电过压',1,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'供电低压',2,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'供电过流',3,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'漏电报警',4,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相线缆温度超高',5,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相线缆温度超高',6,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相线缆温度超高',7,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相电压',65,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相电压',66,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相电压',67,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相电流',68,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相电流',69,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相电流',70,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相线缆温度',71,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相线缆温度',72,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相线缆温度',73,0,'1970-01-01 08:00:00','')").arg(devid));
- }else if(qry2.value(0).toInt()==6){
- mdb.exec(QString::fromUtf8("delete from sp_owner_status where device_id='%1'").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'供电过压',1,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'供电低压',2,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'供电过流',3,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'漏电报警',4,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相线缆温度超高',5,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相线缆温度超高',6,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相线缆温度超高',7,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相电压',65,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相电压',66,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相电压',67,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相电流',68,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相电流',69,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相电流',70,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'A相线缆温度',71,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'B相线缆温度',72,0,'1970-01-01 08:00:00','')").arg(devid));
- mdb.exec(QString::fromUtf8("insert into sp_owner_status (id, device_id, dwtype, point_name, point_code, point_data, data_time, content) values (NULL,'%1',7,'C相线缆温度',73,0,'1970-01-01 08:00:00','')").arg(devid));
- }
- }
- qry2.clear();
- qry2 = mdb.exec(QString("select loop_hl, category,alarm_state, measured_value,a_voltage,b_voltage,c_voltage, a_electric_current,b_electric_current,c_electric_current,acquisition_time,id,a_current_angle,b_current_angle,c_current_angle from %1 where id>%2 and acquisition_time>'%3-%4-%5 00:00:00' and acquisition_time<now()")
- .arg(tbname).arg(sync_id).arg(chkday.year(),4,10,QChar('0')).arg(chkday.month(),2,10,QChar('0')).arg(chkday.day(),2,10,QChar('0')));
- while(qry2.next()){
- updated = true;
- switch(qry2.value(0).toInt()){
- case 1:
- if(count==0){
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(4).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(1).arg(qry2.value(12).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(2).arg(qry2.value(13).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(3).arg(qry2.value(14).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(65).arg(qry2.value(4).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(66).arg(qry2.value(5).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(67).arg(qry2.value(6).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(68).arg(qry2.value(7).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(69).arg(qry2.value(8).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(70).arg(qry2.value(9).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }else{
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(4).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(1).arg(qry2.value(12).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(2).arg(qry2.value(13).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(3).arg(qry2.value(14).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(65).arg(qry2.value(4).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(66).arg(qry2.value(5).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(67).arg(qry2.value(6).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(68).arg(qry2.value(7).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(69).arg(qry2.value(8).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(", (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(70).arg(qry2.value(9).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }
- count += 10;
- upsql1 = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='供电过压' where device_id='%3' and point_code=1;")
- .arg(qry2.value(12).toInt()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql1 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2', point_name='供电低压' where device_id='%3' and point_code=2; ")
- .arg(qry2.value(13).toInt()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql1 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2', point_name='供电过流' where device_id='%3' and point_code=3; ")
- .arg(qry2.value(14).toInt()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql1 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2', point_name='漏电报警' where device_id='%3' and point_code=4; ")
- .arg(qry2.value(2).toInt()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql2 = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='A相电压' where device_id='%3' and point_code=65;")
- .arg(qry2.value(4).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql2 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='B相电压' where device_id='%3' and point_code=66;")
- .arg(qry2.value(5).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql2 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='C相电压' where device_id='%3' and point_code=67;")
- .arg(qry2.value(6).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql3 = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='A相电流' where device_id='%3' and point_code=68; ")
- .arg(qry2.value(7).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql3 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='B相电流' where device_id='%3' and point_code=69; ")
- .arg(qry2.value(8).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql3 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='C相电流' where device_id='%3' and point_code=70; ")
- .arg(qry2.value(9).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- break;
- case 2:
- if(count==0){
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(5).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(71).arg(qry2.value(3).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }else{
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(5).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(71).arg(qry2.value(3).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }
- count += 2;
- upsql4 = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='A相线缆温度超高' where device_id='%3' and point_code=5;")
- .arg(qry2.value(2).toInt()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql4 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='A相线缆温度' where device_id='%3' and point_code=71;")
- .arg(qry2.value(3).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- break;
- case 3:
- if(count==0){
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(6).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(72).arg(qry2.value(3).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }else{
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(6).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(72).arg(qry2.value(3).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }
- count += 2;
- upsql5 = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='B相线缆温度超高' where device_id='%3' and point_code=6;")
- .arg(qry2.value(2).toInt()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql5 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='B相线缆温度' where device_id='%3' and point_code=72;")
- .arg(qry2.value(3).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- break;
- case 4:
- if(count==0){
- sql = QString("insert into sp_owner_sync_data (id, native_id, device_id, point_code, point_data, data_time, content) values (NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(7).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(73).arg(qry2.value(3).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }else{
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(7).arg(qry2.value(2).toInt())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- sql += QString(",(NULL,%1,'%2','%3','%4','%5','')")
- .arg(qry2.value(11).toInt()).arg(devid).arg(73).arg(qry2.value(3).toDouble())
- .arg(qry2.value(10).isNull()?"1970-01-01 08:00:00":qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss"));
- }
- count += 2;
- upsql6 = QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='C相线缆温度超高' where device_id='%3' and point_code=7;")
- .arg(qry2.value(2).toInt()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- upsql6 += QString::fromUtf8("update sp_owner_status set point_data=%1, data_time='%2',point_name='C相线缆温度' where device_id='%3' and point_code=73;")
- .arg(qry2.value(3).toDouble()).arg(qry2.value(10).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(devid);
- break;
- }
- sync_id = qry2.value(11).toUInt();
- if(count>=100){
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql1);
- mdb.exec(upsql2);
- mdb.exec(upsql3);
- mdb.exec(upsql4);
- mdb.exec(upsql5);
- mdb.exec(upsql6);
- count=0;
- sql="";
- upsql1="";
- upsql2="";
- upsql3="";
- upsql4="";
- upsql5="";
- upsql6="";
- }
- }
- if(count>0){
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- sql.append(";");
- mdb.exec(sql);
- mdb.exec(QString("update sp_owner_sync set sync_id=%1 where id=%2").arg(sync_id).arg(ID));
- mdb.exec(upsql1);
- mdb.exec(upsql2);
- mdb.exec(upsql3);
- mdb.exec(upsql4);
- mdb.exec(upsql5);
- mdb.exec(upsql6);
- count=0;
- sql="";
- upsql1="";
- upsql2="";
- upsql3="";
- upsql4="";
- upsql5="";
- upsql6="";
- }
- return updated;
- }
- void DB_SyncThread::appendDevDataList(QString deviceid)
- {
- deviceDataList.append(deviceid);
- }
- void DB_SyncThread::chkInList(QString devid)
- {
- QSqlQuery qry;
- QString sql;
- bool found = false;
- for(int i=0;i<syncDevList.length();i++){
- if(devid.compare(syncDevList.at(i).OwnerCode)==0){
- if(syncDevList.at(i).ObjType.compare("YTFC")==0){
- found = true;
- // system(QString("echo \"%1\" >> /root/test.log").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss")).toUtf8().data());
- // system(QString("echo \"[YTFC] dev:%1 obj:%2 start:%3 rec:%4\">> /root/test.log").arg(syncDevList.at(i).OwnerCode).arg(syncDevList.at(i).ObjCode).arg(syncDevList.at(i).StartPort).arg(syncDevList.at(i).RecCur).toUtf8().data());
- QDateTime dataTime = QDateTime::fromTime_t(0);
- QString PowerAlarm="off";
- QString ManualAct = "off";
- QString DevWorking01 = "off";
- QString DevWorking02 = "off";
- QString DevAlarm01 = "off";
- QString DevAlarm02 = "off";
- QString FireAutoAct = "off";
- sql = QString("select dwtype,point_code,point_data,data_time from sp_owner_status where device_id='%1'").arg(devid);
- // system(QString("echo \"[YTFC] %1\" >> /root/test.log").arg(sql).toUtf8().data());
- // qDebug()<<sql.toUtf8().data();
- qry = mdb.exec(sql);
- while(qry.next()){
- int code = qry.value(1).toInt();
- if((code>0)&&(code<8)){
- int value = qry.value(2).toInt();
- if(dataTime.toTime_t()<qry.value(3).toDateTime().toTime_t())
- dataTime = qry.value(3).toDateTime();
- if(code==1){
- if(value==0)
- PowerAlarm = "on";
- }else if(code==2){
- if(value==0)
- ManualAct = "on";
- }else if(code==3){
- if(value==0)
- DevWorking01 = "on";
- }else if(code==4){
- if(value==0)
- DevWorking02 = "on";
- }else if(code==5){
- if(value==0)
- DevAlarm01 = "on";
- }else if(code==6){
- if(value==0)
- DevAlarm02 = "on";
- }else if(code==7){
- if(value==0)
- FireAutoAct = "on";
- }
- }
- }
- // if(dataTime.toTime_t()>syncDevList.at(i).RecCur)
- {
- mdb.exec(QString("update sp_yangpu_share set rec_cur=%1 where object_code='%2'").arg(dataTime.toTime_t()).arg(syncDevList.at(i).ObjCode));
- QString jsonstr = QString("{\"dataCode\":\"DATA_FIRECONT\",\"deviceId\":\"%1\",\"postTime\":\"%2\",\"data\":{\"PowerAlarm\":\"%3\",\"ManualAct\":\"%4\",\"DevWorking01\":\"%5\",\"DevWorking02\":\"%6\",\"DevAlarm01\":\"%7\",\"DevAlarm02\":\"%8\",\"FireAutoAct\":\"%9\"}}")
- .arg(syncDevList.at(i).ObjCode).arg(dataTime.toString("yyyy-MM-dd HH:mm:ss")).arg(PowerAlarm).arg(ManualAct).arg(DevWorking01).arg(DevWorking02).arg(DevAlarm01).arg(DevAlarm02).arg(FireAutoAct);
- // system(QString("echo \"[YTFC] %1\" >> /root/test.log").arg(jsonstr).toUtf8().data());
- emit SyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), jsonstr);
- }
- }else if(syncDevList.at(i).ObjType.compare("YTCI")==0){
- found = true;
- // system(QString("echo \"%1\" >> /root/test.log").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss")).toUtf8().data());
- // system(QString("echo \"[YTCI] dev:%1 obj:%2 start:%3 rec:%4\">> /root/test.log").arg(syncDevList.at(i).OwnerCode).arg(syncDevList.at(i).ObjCode).arg(syncDevList.at(i).StartPort).arg(syncDevList.at(i).RecCur).toUtf8().data());
- QString Temperature = "0.0";
- QString Humidity = "0.0";
- QDateTime dataTime = QDateTime::fromTime_t(0);
- sql = QString("select dwtype,point_code,point_data,data_time from sp_owner_status where device_id='%1' and point_code>%2 order by point_code limit 0,2").arg(devid).arg((syncDevList.at(i).StartPort>0)?(syncDevList.at(i).StartPort+63):0);
- // system(QString("echo \"[YTCI]%1\" >> /root/test.log").arg(sql).toUtf8().data());
- // qDebug()<<sql.toUtf8().data();
- qry = mdb.exec(sql);
- int nrow = 0;
- while(qry.next()){
- if(dataTime.toTime_t()<qry.value(3).toDateTime().toTime_t())
- dataTime = qry.value(3).toDateTime();
- if(nrow==0)
- Temperature = qry.value(2).toString();
- else if(nrow==1)
- Humidity = qry.value(2).toString();
- nrow++;
- }
- // if(dataTime.toTime_t()>syncDevList.at(i).RecCur)
- {
- mdb.exec(QString("update sp_yangpu_share set rec_cur=%1 where object_code='%2'").arg(dataTime.toTime_t()).arg(syncDevList.at(i).ObjCode));
- QString jsonstr = QString("{\"dataCode\":\"DATA_ENVIRONM\",\"deviceId\":\"%1\",\"postTime\":\"%2\",\"data\":{\"Temperature\":%3,\"Humidity\":%4}}")
- .arg(syncDevList.at(i).ObjCode).arg(dataTime.toString("yyyy-MM-dd HH:mm:ss")).arg(Temperature).arg(Humidity);
- // system(QString("echo \"[YTCI] %1\" >> /root/test.log").arg(jsonstr).toUtf8().data());
- emit SyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), jsonstr);
- }
- }else if(syncDevList.at(i).ObjType.compare("YTWP")==0){
- found = true;
- // system(QString("echo \"%1\" >> /root/test.log").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss")).toUtf8().data());
- // system(QString("echo \"[YTWP] dev:%1 obj:%2 start:%3 rec:%4\">> /root/test.log").arg(syncDevList.at(i).OwnerCode).arg(syncDevList.at(i).ObjCode).arg(syncDevList.at(i).StartPort).arg(syncDevList.at(i).RecCur).toUtf8().data());
- QString WaterPressure = "0.0";
- QDateTime dataTime = QDateTime::fromTime_t(0);
- sql = QString("select dwtype,point_code,point_data,data_time from sp_owner_status where device_id='%1' and point_code>%2 order by point_code limit 0,1").arg(devid).arg((syncDevList.at(i).StartPort>0)?(syncDevList.at(i).StartPort+63):3);
- // system(QString("echo \"[YTWP]%1\" >> /root/test.log").arg(sql).toUtf8().data());
- // qDebug()<<sql.toUtf8().data();
- qry = mdb.exec(sql);
- if(qry.next()){
- if(dataTime.toTime_t()<qry.value(3).toDateTime().toTime_t())
- dataTime = qry.value(3).toDateTime();
- WaterPressure = qry.value(2).toString();
- // if(dataTime.toTime_t()>syncDevList.at(i).RecCur)
- {
- mdb.exec(QString("update sp_yangpu_share set rec_cur=%1 where object_code='%2'").arg(dataTime.toTime_t()).arg(syncDevList.at(i).ObjCode));
- QString jsonstr = QString("{\"dataCode\":\"DATA_WATERPRE\",\"deviceId\":\"%1\",\"postTime\":\"%2\",\"data\":{\"WaterPressure\":%3}}")
- .arg(syncDevList.at(i).ObjCode).arg(dataTime.toString("yyyy-MM-dd HH:mm:ss")).arg(WaterPressure);
- // system(QString("echo \"[YTWP] %1\" >> /root/test.log").arg(jsonstr).toUtf8().data());
- emit SyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), jsonstr);
- }
- }
- }else if(syncDevList.at(i).ObjType.compare("YTLL")==0){
- found = true;
- // system(QString("echo \"%1\" >> /root/test.log").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss")).toUtf8().data());
- // system(QString("echo \"[YTLL] dev:%1 obj:%2 start:%3 rec:%4\">> /root/test.log").arg(syncDevList.at(i).OwnerCode).arg(syncDevList.at(i).ObjCode).arg(syncDevList.at(i).StartPort).arg(syncDevList.at(i).RecCur).toUtf8().data());
- QString LiquidLevel = "0.0";
- QDateTime dataTime = QDateTime::fromTime_t(0);
- sql = QString("select dwtype,point_code,point_data,data_time from sp_owner_status where device_id='%1' and point_code>%2 order by point_code limit 0,1").arg(devid).arg((syncDevList.at(i).StartPort>0)?(syncDevList.at(i).StartPort+63):3);
- // system(QString("echo \"[YTLL]%1\" >> /root/test.log").arg(sql).toUtf8().data());
- // qDebug()<<sql.toUtf8().data();
- qry = mdb.exec(sql);
- if(qry.next()){
- if(dataTime.toTime_t()<qry.value(3).toDateTime().toTime_t())
- dataTime = qry.value(3).toDateTime();
- LiquidLevel = qry.value(2).toString();
- // if(dataTime.toTime_t()>syncDevList.at(i).RecCur)
- {
- mdb.exec(QString("update sp_yangpu_share set rec_cur=%1 where object_code='%2'").arg(dataTime.toTime_t()).arg(syncDevList.at(i).ObjCode));
- QString jsonstr = QString("{\"dataCode\":\"DATA_LIQUIDLE\",\"deviceId\":\"%1\",\"postTime\":\"%2\",\"data\":{\"LiquidLevel\":%3}}")
- .arg(syncDevList.at(i).ObjCode).arg(dataTime.toString("yyyy-MM-dd HH:mm:ss")).arg(LiquidLevel);
- // system(QString("echo \"[YTLL] %1\" >> /root/test.log").arg(jsonstr).toUtf8().data());
- emit SyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), jsonstr);
- }
- }
- }else if(syncDevList.at(i).ObjType.compare("YTEF")==0){
- found = true;
- // system(QString("echo \"%1\" >> /root/test.log").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss")).toUtf8().data());
- // system(QString("echo \"[YTEF] dev:%1 obj:%2 start:%3 rec:%4\">> /root/test.log").arg(syncDevList.at(i).OwnerCode).arg(syncDevList.at(i).ObjCode).arg(syncDevList.at(i).StartPort).arg(syncDevList.at(i).RecCur).toUtf8().data());
- QString HighVoltageAlarm ="off";
- QString LowVoltageAlarm = "off";
- QString HighCurrentAlarm = "off";
- QString ElectricityLeakage = "off";
- QString HighTemperatureA = "off";
- QString HighTemperatureB = "off";
- QString HighTemperatureC = "off";
- QString VoltageA = "0.0";
- QString VoltageB = "0.0";
- QString VoltageC = "0.0";
- QString CurrentA = "0.0";
- QString CurrentB = "0.0";
- QString CurrentC = "0.0";
- QString TemperatureA = "0.0";
- QString TemperatureB = "0.0";
- QString TemperatureC = "0.0";
- QDateTime dataTime = QDateTime::fromTime_t(0);
- sql =QString("select dwtype,point_code,point_data,data_time from sp_owner_status where device_id='%1'").arg(devid);
- // system(QString("echo \"[YTEF]%1\" >> /root/test.log").arg(sql).toUtf8().data());
- // qDebug()<<sql.toUtf8().data();
- qry = mdb.exec(sql);
- while(qry.next()){
- if(dataTime.toTime_t()<qry.value(3).toDateTime().toTime_t())
- dataTime = qry.value(3).toDateTime();
- int code = qry.value(1).toInt();
- if(code==1){
- if(qry.value(2).toInt()==1)
- HighVoltageAlarm = "on";
- }else if(code==2){
- if(qry.value(2).toInt()==1)
- LowVoltageAlarm = "on";
- }else if(code==3){
- if(qry.value(2).toInt()==1)
- HighCurrentAlarm = "on";
- }else if(code==4){
- if(qry.value(2).toInt()==1)
- ElectricityLeakage = "on";
- }else if(code==5){
- if(qry.value(2).toInt()==1)
- HighTemperatureA = "on";
- }else if(code==6){
- if(qry.value(2).toInt()==1)
- HighTemperatureB = "on";
- }else if(code==7){
- if(qry.value(2).toInt()==1)
- HighTemperatureC = "on";
- }else if(code==65)
- VoltageA = qry.value(2).toString();
- else if(code==66)
- VoltageB = qry.value(2).toString();
- else if(code==67)
- VoltageC = qry.value(2).toString();
- else if(code==68)
- CurrentA = qry.value(2).toString();
- else if(code==69)
- CurrentB = qry.value(2).toString();
- else if(code==70)
- CurrentC = qry.value(2).toString();
- else if(code==71)
- TemperatureA = qry.value(2).toString();
- else if(code==72)
- TemperatureB = qry.value(2).toString();
- else if(code==73)
- TemperatureC = qry.value(2).toString();
- }
- // if(dataTime.toTime_t()>syncDevList.at(i).RecCur)
- {
- mdb.exec(QString("update sp_yangpu_share set rec_cur=%1 where object_code='%2'").arg(dataTime.toTime_t()).arg(syncDevList.at(i).ObjCode));
- QString jsonstr = QString("{\"dataCode\":\"DATA_ElECTRIC\",\"deviceId\":\"%1\",\"postTime\":\"%2\",\"data\":{\"HighVoltageAlarm\":\"%3\",\"LowVoltageAlarm\":\"%4\",\"HighCurrentAlarm\":\"%5\",\"ElectricityLeakage\":\"%6\",\"HighTemperatureA\":\"%7\",\"HighTemperatureB\":\"%8\",\"HighTemperatureC\":\"%9\",\"VoltageA\":%10,\"VoltageB\":%11,\"VoltageC\":%12,\"CurrentA\":%13,\"CurrentB\":%14,\"CurrentC\":%15,\"TemperatureA\":%16,\"TemperatureB\":%17,\"TemperatureC\":%18}}")
- .arg(syncDevList.at(i).ObjCode).arg(dataTime.toString("yyyy-MM-dd HH:mm:ss")).arg(HighVoltageAlarm).arg(LowVoltageAlarm).arg(HighCurrentAlarm).arg(ElectricityLeakage).arg(HighTemperatureA).arg(HighTemperatureB).arg(HighTemperatureC).arg(VoltageA).arg(VoltageB).arg(VoltageC).arg(CurrentA).arg(CurrentB).arg(CurrentC).arg(TemperatureA).arg(TemperatureB).arg(TemperatureC);
- // system(QString("echo \"[YTEF] %1\" >> /root/test.log").arg(jsonstr).toUtf8().data());
- emit SyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), jsonstr);
- }
- }else if(syncDevList.at(i).ObjType.compare("YTVA")==0){
- found = true;
- QString VideoAlarm01 = "off";
- QString VideoAlarm02 = "off";
- QDateTime dataTime = QDateTime::fromTime_t(0);
- sql =QString("select dwtype,point_code,point_data,data_time from sp_owner_status where device_id='%1'").arg(devid);
- // system(QString("echo \"%1\" >> /root/test.log").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss")).toUtf8().data());
- qry = mdb.exec(sql);
- while(qry.next()){
- if(dataTime.toTime_t()<qry.value(3).toDateTime().toTime_t()){
- dataTime = qry.value(3).toDateTime();
- int code = qry.value(1).toInt();
- if(code==1){
- if(qry.value(2).toInt()==1){
- VideoAlarm01 = "on";
- VideoAlarm02 = "off";
- }
- }else if(code==2){
- if(qry.value(2).toInt()==1){
- VideoAlarm01 = "off";
- VideoAlarm02 = "on";
- }
- }
- }
- }
- // mdb.exec(QString("update sp_yangpu_share set rec_cur=%1 where object_code='%2'").arg(dataTime.toTime_t()).arg(syncDevList.at(i).ObjCode));
- QString jsonstr = QString("{\"dataCode\":\"DATA_VIDEOALA\",\"deviceId\":\"%1\",\"postTime\":\"%2\",\"data\":{\"VideoAlarm01\":\"%3\",\"VideoAlarm02\":\"%4\"}}")
- .arg(syncDevList.at(i).ObjCode).arg(dataTime.toString("yyyy-MM-dd HH:mm:ss")).arg(VideoAlarm01).arg(VideoAlarm02);
- // system(QString("echo \"[YTVA] %1\" >> /root/test.log").arg(jsonstr).toUtf8().data());
- emit SyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), jsonstr);
- }
- }
- }
- if(!found){
- for(int i=0;i<cnDevList.length();i++){
- // if(found&&(devid.compare(cnDevList.at(i).OwnerCode)!=0))
- // break;
- if(devid.compare(cnDevList.at(i).OwnerCode)==0){
- found = true;
- if(cnDevList.at(i).ObjType.compare("YTUI")!=0){
- CNSyncDev cndev = cnDevList.at(i);
- uint MaxT = 0;
- QString sql = QString("select point_code, point_data, data_time from sp_owner_status where device_id=%1").arg(devid);
- QString jdata = "";
- jdata.append(QString("\"devCategory\":%1").arg(cndev.devCategory));
- jdata.append(QString(",\"devDesc\":\"%1\"").arg(cndev.ObjName));
- jdata.append(QString(",\"devId\":\"%1\"").arg(cndev.ObjCode));
- jdata.append(QString(",\"devName\":\"%1\"").arg(cndev.ObjName));
- jdata.append(QString(",\"ownBid\":\"%1\"").arg(cndev.ownBid));
- jdata.append(QString(",\"type\":%1").arg(cndev.subType));
- qry = mdb.exec(sql);
- if(cnDevList.at(i).StartPort.length()>0){
- QList<CnPno> pnoList = getPnoValue(cnDevList.at(i).StartPort);
- for(int i=0;i<pnoList.length();i++){
- if(pnoList.at(i).Pno<0){
- if(pnoList.at(i).PName.compare("devStatus")==0)
- jdata.append(QString(",\"devStatus\":%1").arg(pnoList.at(i).Default.length()>0?pnoList.at(i).Default:"0"));
- else
- jdata.append(QString(",\"%1\":\"%2\"").arg(pnoList.at(i).PName).arg(pnoList.at(i).Default));
- }
- }
- while(qry.next()){
- uint cTime = qry.value(2).toDateTime().toTime_t();
- if(cTime>MaxT)
- MaxT = cTime;
- for(int i=0;i<pnoList.length();i++){
- if(pnoList.at(i).Pno==qry.value(0).toInt()){
- if(pnoList.at(i).PName.compare("startStatus")==0)
- jdata.append(QString(",\"%1\":\"%2\"").arg(pnoList.at(i).PName).arg(qry.value(1).toInt()));
- else if(pnoList.at(i).PName.indexOf("Status")>=0)
- jdata.append(QString(",\"%1\":%2").arg(pnoList.at(i).PName).arg(qry.value(1).toInt()));
- else
- jdata.append(QString(",\"%1\":%2").arg(pnoList.at(i).PName).arg(qry.value(1).toString()));
- break;
- }
- }
- }
- }else{
- while(qry.next()){
- uint cTime = qry.value(2).toDateTime().toTime_t();
- if(cTime>MaxT)
- MaxT = cTime;
- if(cndev.ObjType.compare("YTWP")==0){
- if(qry.value(0).toInt()==1)
- jdata.append(QString(",\"devStatus\":%1").arg(qry.value(1).toInt()));
- else if(qry.value(0).toInt()==2)
- jdata.append(QString(",\"power\":%1").arg(qry.value(1).toInt()));
- else if(qry.value(0).toInt()==3)
- jdata.append(QString(",\"signal\":%1").arg((qry.value(1).toInt()==5)?100:(qry.value(1).toInt()*20)));
- else if(qry.value(0).toInt()==4)
- jdata.append(QString(",\"value\":%1").arg(qry.value(1).toDouble()));
- }
- }
- if(cndev.ObjType.compare("YTWP")==0)
- jdata.append(QString(",\"unit\":\"MPa\""));
- }
- jdata.append(QString(",\"logTime\":\"%1\"").arg(QDateTime::fromTime_t(MaxT).toString("yyyy-MM-dd HH:mm:ss")));
- emit cnSyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), "{"+jdata+"}",cndev.devCategory);
- }else{
- }
- }
- }
- }
- }
- //QList<JaPno> DB_SyncThread::getJaPnoValue(QString pnoset)
- //{
- // QList<JaPno> list;
- // QJsonParseError json_error;
- // QJsonDocument jsonDoc(QJsonDocument::fromJson(pnoset.toUtf8(),&json_error));
- // if(json_error.error == QJsonParseError::NoError){
- // QJsonArray json_root = jsonDoc.array();
- // for(int i=0;i<json_root.size();i++){
- // QJsonObject obj = json_root.at(i).toObject();
- // QString name = obj.value("name").toString();
- // QString attr = obj.value("attr").toString();
- // int port = obj.value("port").toInt();
- // QString defvalue1 = obj.value("default1").toString();
- // QString defvalue2 = obj.value("default2").toString();
- // if((port>-2)&&(name.length()>0))
- // list.append(JaPno(name,attr,port,defvalue1,defvalue2));
- // }
- // }
- // return list;
- //}
- QList<CnPno> DB_SyncThread::getPnoValue(QString pnoset)
- {
- QList<CnPno> list;
- QJsonParseError json_error;
- QJsonDocument jsonDoc(QJsonDocument::fromJson(pnoset.toUtf8(),&json_error));
- if(json_error.error == QJsonParseError::NoError){
- QJsonArray json_root = jsonDoc.array();
- for(int i=0;i<json_root.size();i++){
- QJsonObject obj = json_root.at(i).toObject();
- QString name = obj.value("name").toString();
- int port = obj.value("port").toInt();
- QString defvalue = obj.value("default").toString();
- if((port>-2)&&(name.length()>0))
- list.append(CnPno(name,port,defvalue));
- }
- }
- // int i,port;
- // json_object *pno, *obj;
- // char name[1024],value[1024];
- // obj = json_tokener_parse(pnoset.toUtf8().data());
- // if(json_object_get_type(obj)==json_type_array){
- // for(i=0;i<json_object_array_length(obj);i++){
- // pno = json_object_array_get_idx(obj,i);
- // bzero(name,sizeof(name));
- // bzero(value,sizeof(value));
- // port=-2;
- // json_object_object_foreach(pno,key,val){
- // if(strcmp(key,"name")==0)
- // sprintf(name,"%s",json_object_get_string(val));
- // else if(strcmp(key,"port")==0)
- // port = json_object_get_int(val);
- // else if(strcmp(key,"default")==0)
- // sprintf(value,"%s",json_object_get_string(val));
- // }
- // if((port>-2)&&(strlen(name)>0)){
- // list.append(CnPno(QString::fromUtf8(name),port,QString::fromUtf8(value)));
- // }
- // }
- // }
- // json_object_put(obj);
- return list;
- }
- void DB_SyncThread::updatePortName()
- {
- QSqlQuery qry = mdb.exec("select s.owner_code, o.owner_name, o.unitinfo from sp_owner_sync s, sp_owner o where s.owner_code=o.owner_code and (s.owner_name<>o.owner_name or s.unitinfo<>o.unitinfo) group by s.owner_code");
- while(qry.next()){
- QString sql = QString("update sp_owner_sync set owner_name='%1', unitinfo='%2' where owner_code='%3'")
- .arg(qry.value(1).toString()).arg(qry.value(2).toString()).arg(qry.value(0).toString());
- printf("echo '%s' >> /root/sql.txt\n",sql.toUtf8().data());
- mdb.exec(sql);
- }
- }
- void DB_SyncThread::va_heartbeat(){
- int ret = 0;
- for(int i=0;i<syncDevList.length();i++){
- if(syncDevList.at(i).ObjType.compare("YTVA")==0){
- QString jsonstr = QString("{\"dataCode\":\"DATA_VIDEOALA\",\"deviceId\":\"%1\",\"postTime\":\"%2\",\"data\":{\"VideoAlarm01\":\"%3\",\"VideoAlarm02\":\"%4\"}}")
- .arg(syncDevList.at(i).ObjCode).arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg("off").arg("off");
- ret = system(QString("echo '%1' >> /root/heartbeat.log").arg(jsonstr).toUtf8().data());
- emit SyncData(QUuid::createUuid().toString().replace("{","").replace("}",""), jsonstr);
- }
- }
- }
- void DB_SyncThread::time_out()
- {
- QSqlQuery qry,qry2;
- QString qrysql;
- if(!isWorking)
- {
- printf("update memory at %s\n",QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss.zzz").toUtf8().data());
- UpdateTime = QDateTime::currentDateTime().toTime_t();
- isWorking = true;
- if(!mdbOpened)
- {
- mdbOpened = mdb.open();
- }
- else
- {
- if(((times++)&0x0f)==0x0f){
- UpdateTime = QDateTime::currentDateTime().toTime_t();
- checkUsers();
- checkCompany();
- checkDevice();
- updatePortName();
- }
- syncDevList.clear();
- qry = mdb.exec("select owner_code,dwtype,object_code,start_port,rec_cur from sp_yangpu_share");
- while(qry.next()){
- syncDevList.append(YPSyncDev(qry.value(0).toString(),
- qry.value(1).toString(),
- qry.value(2).toString(),
- qry.value(3).toInt(),
- qry.value(4).toUInt()));
- }
- qry.clear();
- if(day!=QDate::currentDate().day()){
- day = QDate::currentDate().day();
- va_heartbeat();
- }
- cnDevList.clear();
- qry = mdb.exec("select owner_code,dwtype,object_code,start_port,rec_cur,object_name, ownBid, devCategory, type from sp_changning_share");
- while(qry.next()){
- cnDevList.append(CNSyncDev(qry.value(0).toString(),
- qry.value(5).toString(),
- qry.value(1).toString(),
- qry.value(2).toString(),
- qry.value(3).toString().trimmed(),
- qry.value(4).toUInt(),
- qry.value(6).toString(),
- qry.value(7).toInt(),
- qry.value(8).toInt()));
- }
- qry.clear();
- qry2 = mdb.exec("select device_id,point_code from sp_owner_status");
- dList.clear();
- pcList.clear();
- while(qry2.next()){
- dList.append(qry2.value(0).toString());
- pcList.append(qry2.value(1).toInt());
- }
- qry2.clear();
- qry = mdb.exec("select id, owner_code, owner_name, unitinfo, install_time, dwtype, company, rtmp from sp_owner");
- while(qry.next())
- {
- time_t tmp_time = time(static_cast<time_t *>(Q_NULLPTR));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- int dwtype = qry.value(5).toInt();
- uint ID = qry.value(0).toUInt();
- QString companyCode = qry.value(6).toString();
- QDate chkday = QDate::currentDate().addDays(-7);
- bool need_sync = false;
- qry2 =mdb.exec(QString("select count(*) from sp_device_sync where device_id='%1'").arg(qry.value(1).toString()));
- if(qry2.next()){
- if(qry2.value(0).toInt()==0){
- mdb.exec(QString("insert into sp_device_sync (device_id,com_count,com_confirm,alm_count,alm_confirm) values ('%1',0,0,0,0)").arg(qry.value(1).toString()));
- }
- }
- qry2.clear();
- qrysql = QString("select count(*),table_name,sync_id from sp_owner_sync where id=%1").arg(ID);
- qry2 = mdb.exec(qrysql);
- if(qry2.next()){
- QString deviceCode = qry.value(1).toString();
- QString tbname = QString("sp_%1%2").arg(qry.value(5).toInt()==3?"y":"d").arg(deviceCode);
- uint sync_id = 0;
- if(qry2.value(0).toInt()==0){
- mdb.exec(QString("insert into sp_owner_sync (id, owner_code, owner_name, unitinfo, install_time, dwtype, company, rtmp, table_name, sync_id) values (%1,'%2','%3', '%4', '%5', %6, '%7', '%8', '%9', %10) ")
- .arg(qry.value(0).toInt()).arg(qry.value(1).toString()).arg(qry.value(2).toString()).arg(qry.value(3).toString()).arg(qry.value(4).toString())
- .arg(qry.value(5).toInt()).arg(qry.value(6).toString()).arg(qry.value(7).toString()).arg(tbname).arg(sync_id));
- }else{
- sync_id = qry2.value(2).toUInt();
- }
- qry2.clear();
- switch(dwtype){
- case 1://userinfo
- need_sync = userInfoSync(qry.value(1).toString(),deviceCode,sync_id, tbname, chkday,ID,companyCode);
- break;
- case 2://water
- case 5:
- need_sync = waterInfoSync(qry.value(1).toString(),deviceCode,sync_id,tbname,chkday,ID,dwtype,companyCode);
- break;
- case 3:
- need_sync = smokerInfoSync(qry.value(1).toString(),deviceCode,sync_id,tbname,chkday,ID,companyCode);
- break;
- case 6:
- need_sync = rtuInfoSync(qry.value(1).toString(),deviceCode,sync_id,tbname,chkday,ID,companyCode);
- break;
- case 7:
- need_sync = efireInfoSync(qry.value(1).toString(),deviceCode,sync_id,tbname,chkday,ID,companyCode);
- break;
- case 16:
- need_sync = videoalarmSync(qry.value(1).toString(),deviceCode,sync_id,tbname,chkday,ID,companyCode);
- // need_sync = false;//debug
- break;
- }
- qry2.clear();
- if(need_sync)
- chkInList(qry.value(1).toString());
- }
- usleep(5000);
- }
- if(deviceDataList.length()>0){
- while (deviceDataList.length()>0) {
- chkInList(deviceDataList.first());
- deviceDataList.removeFirst();
- usleep(5000);
- }
- }
- qry.clear();
- qry = mdb.exec("select a.company as company, a.dwtype as dwtype, sum(a.devCount) as devCount, sum(a.com_count) as comCount, sum(a.com_confirm) as comConfirm, sum(a.alm_count) as almCount, sum(a.alm_confirm) as almConfirm from (select sp_owner.company, sp_device_sync.device_id, if(sp_owner.dwtype=3,1,sp_owner.dwtype) as dwtype, 1 as devCount, sp_device_sync.com_count, sp_device_sync.com_confirm, sp_device_sync.alm_count, sp_device_sync.alm_confirm from sp_owner, sp_device_sync where sp_owner.owner_code = sp_device_sync.device_id) a where a.dwtype in (1,2,5,6,7,16) and a.company<>'' group by a.company, a.dwtype");
- while(qry.next()){
- QString sql2="";
- qry2 = mdb.exec(QString("select count(*) from sp_company_sync where company_code='%1'").arg(qry.value(0).toString()));
- if(qry2.next()){
- if(qry2.value(0).toInt()==0){
- sql2 = QString("insert into sp_company_sync (company_code, device_00_count, device_00_out, device_00_out_confirm, device_00_alarm, device_00_alarm_confirm,device_01_count, device_01_out, device_01_out_confirm, device_01_alarm, device_01_alarm_confirm, device_02_count, device_02_out, device_02_out_confirm, device_02_alarm, device_02_alarm_confirm,device_06_count, device_06_out, device_06_out_confirm, device_06_alarm, device_06_alarm_confirm,device_07_count, device_07_out, device_07_out_confirm, device_07_alarm, device_07_alarm_confirm,device_16_count, device_16_out, device_16_out_confirm, device_16_alarm, device_16_alarm_confirm) values ('%1',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);")
- .arg(qry.value(0).toString());
- }
- }
- qry2.clear();
- if(qry.value(1).toInt()==1){
- sql2 += QString("update sp_company_sync set device_01_count=%1, device_01_out=%2, device_01_out_confirm=%3, device_01_alarm=%4, device_01_alarm_confirm=%5 where company_code='%6'")
- .arg(qry.value(2).toInt()).arg(qry.value(3).toInt()).arg(qry.value(4).toInt()).arg(qry.value(5).toInt()).arg(qry.value(6).toInt()).arg(qry.value(0).toString());
- update_company_alarmstatus(qry.value(0).toString(),1,qry.value(2).toUInt(),qry.value(3).toUInt(),qry.value(4).toUInt(),qry.value(5).toUInt(),qry.value(6).toUInt());
- }else if(qry.value(1).toInt()==2){
- sql2 += QString("update sp_company_sync set device_02_count=%1, device_02_out=%2, device_02_out_confirm=%3, device_02_alarm=%4, device_02_alarm_confirm=%5 where company_code='%6'")
- .arg(qry.value(2).toInt()).arg(qry.value(3).toInt()).arg(qry.value(4).toInt()).arg(qry.value(5).toInt()).arg(qry.value(6).toInt()).arg(qry.value(0).toString());
- update_company_alarmstatus(qry.value(0).toString(),2,qry.value(2).toUInt(),qry.value(3).toUInt(),qry.value(4).toUInt(),qry.value(5).toUInt(),qry.value(6).toUInt());
- }else if(qry.value(1).toInt()==3){
- sql2 += QString("update sp_company_sync set device_03_count=%1, device_03_out=%2, device_03_out_confirm=%3, device_03_alarm=%4, device_03_alarm_confirm=%5 where company_code='%6'")
- .arg(qry.value(2).toInt()).arg(qry.value(3).toInt()).arg(qry.value(4).toInt()).arg(qry.value(5).toInt()).arg(qry.value(6).toInt()).arg(qry.value(0).toString());
- update_company_alarmstatus(qry.value(0).toString(),1,qry.value(2).toUInt(),qry.value(3).toUInt(),qry.value(4).toUInt(),qry.value(5).toUInt(),qry.value(6).toUInt());
- }else if(qry.value(1).toInt()==5){
- sql2 += QString("update sp_company_sync set device_00_count=%1, device_00_out=%2, device_00_out_confirm=%3, device_00_alarm=%4, device_00_alarm_confirm=%5 where company_code='%6'")
- .arg(qry.value(2).toInt()).arg(qry.value(3).toInt()).arg(qry.value(4).toInt()).arg(qry.value(5).toInt()).arg(qry.value(6).toInt()).arg(qry.value(0).toString());
- update_company_alarmstatus(qry.value(0).toString(),0,qry.value(2).toUInt(),qry.value(3).toUInt(),qry.value(4).toUInt(),qry.value(5).toUInt(),qry.value(6).toUInt());
- }else if(qry.value(1).toInt()==6){
- sql2 += QString("update sp_company_sync set device_06_count=%1, device_06_out=%2, device_06_out_confirm=%3, device_06_alarm=%4, device_06_alarm_confirm=%5 where company_code='%6'")
- .arg(qry.value(2).toInt()).arg(qry.value(3).toInt()).arg(qry.value(4).toInt()).arg(qry.value(5).toInt()).arg(qry.value(6).toInt()).arg(qry.value(0).toString());
- update_company_alarmstatus(qry.value(0).toString(),6,qry.value(2).toUInt(),qry.value(3).toUInt(),qry.value(4).toUInt(),qry.value(5).toUInt(),qry.value(6).toUInt());
- }else if(qry.value(1).toInt()==7){
- sql2 += QString("update sp_company_sync set device_07_count=%1, device_07_out=%2, device_07_out_confirm=%3, device_07_alarm=%4, device_07_alarm_confirm=%5 where company_code='%6'")
- .arg(qry.value(2).toInt()).arg(qry.value(3).toInt()).arg(qry.value(4).toInt()).arg(qry.value(5).toInt()).arg(qry.value(6).toInt()).arg(qry.value(0).toString());
- update_company_alarmstatus(qry.value(0).toString(),7,qry.value(2).toUInt(),qry.value(3).toUInt(),qry.value(4).toUInt(),qry.value(5).toUInt(),qry.value(6).toUInt());
- }else if(qry.value(1).toInt()==16){
- sql2 += QString("update sp_company_sync set device_16_count=%1, device_16_out=%2, device_16_out_confirm=%3, device_16_alarm=%4, device_16_alarm_confirm=%5 where company_code='%6'")
- .arg(qry.value(2).toInt()).arg(qry.value(3).toInt()).arg(qry.value(4).toInt()).arg(qry.value(5).toInt()).arg(qry.value(6).toInt()).arg(qry.value(0).toString());
- update_company_alarmstatus(qry.value(0).toString(),16,qry.value(2).toUInt(),qry.value(3).toUInt(),qry.value(4).toUInt(),qry.value(5).toUInt(),qry.value(6).toUInt());
- }
- mdb.exec(sql2);
- qry2.clear();
- usleep(5000);
- }
- qry.clear();
- QDate d_day = QDate::currentDate().addDays(-7);
- QString delsql = QString("delete from sp_owner_sync_data where data_time<'%1-%2-%3 00:00:00'").arg(d_day.year(),4,10,QChar('0')).arg(d_day.month(),2,10,QChar('0')).arg(d_day.day(),2,10,QChar('0'));
- mdb.exec(delsql);
- qry = mdb.exec("select sp_owner_status.id, sp_owner_status.device_id, sp_owner_status.data_time, sp_owner.dwtype from sp_owner_status, sp_owner where sp_owner_status.device_id=sp_owner.owner_code and sp_owner.dwtype=1 and sp_owner_status.point_data !='0'");
- while(qry.next()){
- qry2 = mdb.exec(QString("select clzt from sp_hj2017 where device_code=%1 and time='%2'")
- .arg(qry.value(1).toString()).arg(qry.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss")));
- if((qry2.next())&&(qry2.value(0).toInt()==1))
- mdb.exec(QString("update sp_owner_status set point_data='0' where id=%1").arg(qry.value(0).toInt()));
- qry.clear();
- usleep(5000);
- }
- qry.clear();
- qry = mdb.exec("select sp_owner_status.id, sp_owner_status.device_id, sp_owner_status.data_time, sp_owner_status.point_data from sp_owner_status, sp_owner where sp_owner_status.point_code=1 and sp_owner_status.device_id=sp_owner.owner_code and (sp_owner.dwtype=2 or sp_owner.dwtype=5) and sp_owner_status.point_data !='0' and sp_owner_status.point_data !='WP0'");
- while(qry.next()){
- qry2 = mdb.exec(QString("select clzt from sp_sj2017 where device_code=%1 and time='%2'")
- .arg(qry.value(1).toString()).arg(qry.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss")));
- if((qry2.next())&&(qry2.value(0).toInt()==1))
- mdb.exec(QString("update sp_owner_status set point_data='0',data_time='%1' where device_id='%2' and point_code=0").arg(qry.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(qry.value(1).toString()));
- else
- mdb.exec(QString("update sp_owner_status set point_data='%1',data_time='%2' where device_id='%3' and point_code=0").arg(qry.value(3).toString()).arg(qry.value(2).toDateTime().toString("yyyy-MM-dd HH:mm:ss")).arg(qry.value(1).toString()));
- usleep(5000);
- }
- mdb.close();
- mdbOpened = false;
- }
- isWorking = false;
- }
- }
- void DB_SyncThread::setCompanyAlarmSet(QString deviceCode, AlarmSet set)
- {
- QString companyCode;
- quint16 companyIdx = 0xffff;
- quint32 deviceIdx = 0xffffffff;
- AlarmSet tmp = AlarmSet(0xffffffff,"","",0xff,0,0);
- for(quint32 i=0;i<102400;i++){
- if(i>=webData->DevicesCount)
- break;
- if(QString::compare(QString(webData->devices[i].DevCode),deviceCode)==0){
- deviceIdx = i;
- companyCode = QString(webData->devices[i].CompanyCode);
- set.DeviceIdx = deviceIdx;
- set.DevName = QString(webData->devices[i].DevName);
- if(set.dwType==16){
- system(QString("echo '%1, %2, %3' >> /root/data.txt").arg(webData->devices[i].CompanyCode)
- .arg(deviceCode).arg(QDateTime::fromTime_t(set.AlarmTime).toString("yyyy-MM-dd HH:mm:ss"))
- .toUtf8().data());
- }
- setLastAlarmSet(static_cast<quint16>(i),set.dwType,set);
- break;
- }
- }
- for(quint16 i=0;i<10240;i++){
- if(i>=webData->CompanysCount)
- break;
- if(QString::compare(QString(webData->companys[i].CompanyCode),companyCode)==0){
- companyIdx = i;
- break;
- }
- }
- if(companyIdx<webData->CompanysCount){
- for(quint8 i=0;i<10;i++){
- if(set.AlarmTime>webData->CompanyAlarm[companyIdx].alarmRec[i].Time_T){
- for(quint8 j=9;j>i;j--){
- get_AlarmSet(companyIdx,j-1,&tmp);
- set_AlarmSet(companyIdx,j,tmp);
- }
- set_AlarmSet(companyIdx,i,set);
- break;
- }
- }
- for(quint8 i=0;i<10;i++){
- if(set.AlarmTime>webData->CompanyAlarm[10239].alarmRec[i].Time_T){
- for(quint8 j=9;j>i;j--){
- get_AlarmSet(10239,j-1,&tmp);
- set_AlarmSet(10239,j,tmp);
- }
- set_AlarmSet(10239,i,set);
- break;
- }
- }
- }
- }
- void DB_SyncThread::set_AlarmSet(quint16 companyIdx, quint8 alarmIdx, AlarmSet set)
- {
- if(((companyIdx<webData->CompanysCount)||(companyIdx==10239))&&(alarmIdx<10)){
- if(set.Enabled==0x01){
- webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].DeviceIdx = set.DeviceIdx;
- sprintf(webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].DevName,"%s",set.DevName.toUtf8().data());
- sprintf(webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].Data,"%s",set.AlarmData.toUtf8().data());
- sprintf(webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].Time,"%s",QDateTime::fromTime_t(set.AlarmTime).toString("yyyy-MM-dd HH:mm:ss").toUtf8().data());
- webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].dwType = set.dwType;
- webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].Time_T = set.AlarmTime;
- webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].ShowFlag = 0x01;
- }else
- webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].ShowFlag = 0x00;
- webData->CompanyAlarm[companyIdx].UpdateTime = UpdateTime;
- }
- }
- void DB_SyncThread::setLastAlarmSet(quint16 companyIdx, quint8 dwtype, AlarmSet set)
- {
- int page=0, dwIdx=0;
- // if(dwtype==16){
- // system(QString("echo '16 to mem: %1 %2 %3 %4' >> /root/data.txt")
- // .arg(companyIdx).arg(webData->CompanysCount).arg(set.DeviceIdx).arg(webData->DevicesCount)
- // .toUtf8().data());
- // }
- if(((companyIdx<webData->CompanysCount)||(companyIdx==10239))&&(dwtype<20)){
- if(dwtype==1){
- page = 0;
- dwIdx = 1;
- }else if(dwtype==2){
- page = 0;
- dwIdx = 2;
- }else if(dwtype==6){
- page = 0;
- dwIdx = 3;
- }else if(dwtype==7){
- page = 0;
- dwIdx = 4;
- }else if(dwtype==16){
- page = 0;
- dwIdx = 5;
- }
- if(set.Enabled==0x01)
- {
- // if(dwtype==16){
- // system(QString("echo 'lastAlarmRec %1 %2 %3 companyIdx:%4 page:%5 dwIdx:%6' >> /root/data.txt")
- // .arg(set.DevName).arg(set.AlarmData).arg(QDateTime::fromTime_t(set.AlarmTime).toString("yyyy-MM-dd HH:mm:ss"))
- // .arg(companyIdx).arg(page).arg(dwIdx).toUtf8().data());
- // }
- webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].DeviceIdx = set.DeviceIdx;
- sprintf(webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].DevName,"%s",set.DevName.toUtf8().data());
- sprintf(webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].Data,"%s",set.AlarmData.toUtf8().data());
- sprintf(webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].Time,"%s",QDateTime::fromTime_t(set.AlarmTime).toString("yyyy-MM-dd HH:mm:ss").toUtf8().data());
- webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].dwType = set.dwType;
- webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].Time_T = set.AlarmTime;
- webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].ShowFlag = 0x01;
- if(!initTime)
- emit companyAlarmChanged(QString(webData->companys[companyIdx].CompanyCode));
- }else
- webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].ShowFlag = 0x00;
- webData->LastAlarmRec[companyIdx][page].UpdateTime = UpdateTime;
- }
- }
- void DB_SyncThread::get_AlarmSet(quint16 companyIdx, quint8 alarmIdx, AlarmSet *set)
- {
- if(((companyIdx<webData->CompanysCount)||(companyIdx==10239))&&(alarmIdx<10)){
- if(webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].ShowFlag==0x01){
- set->Enabled = 0x01;
- set->DeviceIdx = webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].DeviceIdx;
- set->dwType = webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].dwType;
- set->AlarmTime = webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].Time_T;
- set->DevName = QString::fromUtf8(webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].DevName);
- set->AlarmData = QString::fromUtf8(webData->CompanyAlarm[companyIdx].alarmRec[alarmIdx].Data);
- }else{
- set->Enabled = 0x00;
- }
- }
- }
- void DB_SyncThread::getLastAlarmSet(quint16 companyIdx, quint8 dwtype, AlarmSet *set)
- {
- int page=0, dwIdx=0;
- if(((companyIdx<webData->CompanysCount)||(companyIdx==10239))&&(dwtype<20)){
- if(dwtype==1){
- page = 0;
- dwIdx = 1;
- }else if(dwtype==2){
- page = 0;
- dwIdx = 2;
- }else if(dwtype==6){
- page = 0;
- dwIdx = 3;
- }else if(dwtype==7){
- page = 0;
- dwIdx = 4;
- }else if(dwtype==16){
- page = 0;
- dwIdx = 5;
- }
- if(webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].ShowFlag==0x01){
- set->Enabled = 0x01;
- set->DeviceIdx = webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].DeviceIdx;
- set->dwType = webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].dwType;
- set->AlarmTime = webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].Time_T;
- set->DevName = QString::fromUtf8(webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].DevName);
- set->AlarmData = QString::fromUtf8(webData->LastAlarmRec[companyIdx][page].alarmRec[dwIdx].Data);
- }else{
- set->Enabled = 0x00;
- }
- }
- }
- void DB_SyncThread::update_company_alarmstatus(QString companycode, quint8 alarmidx, uint devCount, uint devOut, uint devOutConfirm, uint devAlarmCount, uint devAlarmConfirm)
- {
- uint dC=0,dO=0,dOC=0,dA=0,dAC=0;
- quint16 companyIdx = 0xffff;
- for(quint16 i=0;i<10240;i++){
- if(i>=webData->CompanysCount)
- break;
- if(QString::compare(QString(webData->companys[i].CompanyCode),companycode)==0){
- companyIdx = i;
- break;
- }
- }
- if(companyIdx<webData->CompanysCount){
- for(quint16 i=0;i<10239;i++){
- if(i==companyIdx){
- webData->companys[i].subType[alarmidx].DevCount = devCount;
- webData->companys[i].subType[alarmidx].DevOutLineCount = devOut;
- webData->companys[i].subType[alarmidx].DevOutConfirmCount = devOutConfirm;
- webData->companys[i].subType[alarmidx].DevAlarmCount = devAlarmCount;
- webData->companys[i].subType[alarmidx].DevAlarmConfirmCount = devAlarmConfirm;
- }
- dC += webData->companys[i].subType[alarmidx].DevCount;
- dO += webData->companys[i].subType[alarmidx].DevOutLineCount;
- dOC += webData->companys[i].subType[alarmidx].DevOutConfirmCount;
- dA += webData->companys[i].subType[alarmidx].DevAlarmCount;
- dAC += webData->companys[i].subType[alarmidx].DevAlarmConfirmCount;
- }
- webData->companys[10239].subType[alarmidx].DevCount = dC;
- webData->companys[10239].subType[alarmidx].DevOutLineCount = dO;
- webData->companys[10239].subType[alarmidx].DevOutConfirmCount = dOC;
- webData->companys[10239].subType[alarmidx].DevAlarmCount = dA;
- webData->companys[10239].subType[alarmidx].DevAlarmConfirmCount = dAC;
- }
- }
- void DB_SyncThread::webShmInit()
- {
- // printf("init memory at %s\n",QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss.zzz").toUtf8().data());
- UpdateTime = QDateTime::currentDateTime().toTime_t();
- checkUsers();
- checkCompany();
- checkDevice();
- checkAlarmStatus();
- checkAlarmList();
- initTime = false;
- }
- quint32 DB_SyncThread::getDeviceIdxByDeviceCode(QString deviceCode)
- {
- for(quint32 i=0;i<102400;i++){
- if(webData->devices[i].Enabled==0x01){
- if(QString::compare(deviceCode,QString(webData->devices[i].DevCode))==0){
- return i;
- }
- }
- }
- return 0xffffffff;
- }
- void DB_SyncThread::checkAlarmList()
- {
- QSqlQuery qry;
- QList<AlarmSet> companyAlarmList;
- QList<AlarmSet> allAlarmList;
- int nrow;
- allAlarmList.clear();
- for(quint16 i=0;i<webData->CompanysCount;i++){
- if(strlen(webData->companys[i].CompanyCode)>0){
- companyAlarmList.clear();
- qry = mdb.exec(QString("select h.device_code, h.time, h.data2, h.data4, o.owner_name from sp_hj2017 h, sp_owner o where o.owner_code = h.device_code and o.company='%1' and h.time<now() order by h.time desc limit 0, 10").arg(webData->companys[i].CompanyCode));
- nrow = 0;
- while(qry.next()){
- AlarmSet CompanyAlarm = AlarmSet(getDeviceIdxByDeviceCode(qry.value(0).toString()),qry.value(4).toString(),
- QString::fromUtf8("%1,%2").arg(qry.value(2).toString()).arg(qry.value(3).toString()),
- 1,qry.value(1).toDateTime().toTime_t(),1);
- if(nrow==0)
- setLastAlarmSet(i,1,CompanyAlarm);
- companyAlarmList.append(CompanyAlarm);
- allAlarmList.append(CompanyAlarm);
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- nrow++;
- }
- qry.clear();
- nrow = 0;
- qry = mdb.exec(QString("select s.device_code, s.time, s.data1, s.data4, o.owner_name from sp_sj2017 s, sp_owner o where o.owner_code = s.device_code and o.company='%1' and s.time<now() order by s.time desc limit 0, 10").arg(webData->companys[i].CompanyCode));
- while(qry.next()){
- QString dat1 = qry.value(2).toString();
- QString data1 = QString::compare(dat1,"WP1")==0?QString::fromUtf8("低压"):
- (QString::compare(dat1,"WP2")==0?QString::fromUtf8("高压"):
- (QString::compare(dat1,"WP3")==0?QString::fromUtf8("故障"):
- (QString::compare(dat1,"WP4")==0?QString::fromUtf8("离线"):
- (QString::compare(dat1,"WP0")==0?QString::fromUtf8("恢复"):
- (QString::compare(dat1,"LL1")==0?QString::fromUtf8("低液位"):
- (QString::compare(dat1,"LL2")==0?QString::fromUtf8("高液位"):
- (QString::compare(dat1,"LL3")==0?QString::fromUtf8("故障"):
- (QString::compare(dat1,"LL4")==0?QString::fromUtf8("离线"):
- (QString::compare(dat1,"LL0")==0?QString::fromUtf8("恢复"):"")))))))));
- AlarmSet CompanyAlarm = AlarmSet(getDeviceIdxByDeviceCode(qry.value(0).toString()),qry.value(4).toString(),
- data1+QString::fromUtf8(",")+qry.value(3).toString(),
- 2,qry.value(1).toDateTime().toTime_t(),1);
- if(nrow==0)
- setLastAlarmSet(i,2,CompanyAlarm);
- companyAlarmList.append(CompanyAlarm);
- allAlarmList.append(CompanyAlarm);
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- nrow++;
- }
- qry.clear();
- nrow=0;
- qry = mdb.exec(QString("select r.device_code, r.time, r.data2, r.data4, o.owner_name from sp_rtu2017 r, sp_owner o where o.owner_code = r.device_code and o.company='%1' and r.time<now() order by r.time desc limit 0, 10").arg(webData->companys[i].CompanyCode));
- while(qry.next()){
- AlarmSet CompanyAlarm = AlarmSet(getDeviceIdxByDeviceCode(qry.value(0).toString()),qry.value(4).toString(),
- qry.value(2).toString()+QString::fromUtf8(",")+qry.value(3).toString(),
- 6,qry.value(1).toDateTime().toTime_t(),1);
- if(nrow==0)
- setLastAlarmSet(i,6,CompanyAlarm);
- companyAlarmList.append(CompanyAlarm);
- allAlarmList.append(CompanyAlarm);
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- nrow++;
- }
- qry.clear();
- nrow=0;
- qry = mdb.exec(QString("select e.device_code, e.time, e.data1, o.owner_name from sp_ef2017 e, sp_owner o where o.owner_code = e.device_code and o.company='%1' and e.time<now() order by e.time desc limit 0, 10").arg(webData->companys[i].CompanyCode));
- while(qry.next()){
- QString dat1 = qry.value(2).toString();
- AlarmSet CompanyAlarm = AlarmSet(getDeviceIdxByDeviceCode(qry.value(0).toString()),qry.value(3).toString(),
- QString::compare(dat1,"EF1")==0?QString::fromUtf8("欠压报警"):
- (QString::compare(dat1,"EF2")==0?QString::fromUtf8("过压报警"):
- (QString::compare(dat1,"EF3")==0?QString::fromUtf8("过流告警"):
- (QString::compare(dat1,"EF4")==0?QString::fromUtf8("漏电报警"):
- (QString::compare(dat1,"EF5")==0?QString::fromUtf8("#1线缆温度超高报警"):
- (QString::compare(dat1,"EF6")==0?QString::fromUtf8("#2线缆温度超高报警"):
- (QString::compare(dat1,"EF7")==0?QString::fromUtf8("#3线缆温度超高报警"):
- (QString::compare(dat1,"EF8")==0?QString::fromUtf8("#4线缆温度超高报警"):
- (QString::compare(dat1,"EF9")==0?QString::fromUtf8("设备离线"):
- (QString::compare(dat1,"EF0")==0?QString::fromUtf8("报警撤销"):""))))))))),
- 7,qry.value(1).toDateTime().toTime_t(),1);
- if(nrow==0)
- setLastAlarmSet(i,7,CompanyAlarm);
- companyAlarmList.append(CompanyAlarm);
- allAlarmList.append(CompanyAlarm);
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- nrow++;
- }
- qry.clear();
- nrow=0;
- QString sql = QString("select v.device_code, v.time, v.data4, o.owner_name from sp_video2017 v, sp_owner o where o.owner_code = v.device_code and o.company='%1' and v.time<now() order by v.time desc limit 0, 10").arg(webData->companys[i].CompanyCode);
- // system(QString("echo '%1' >> /root/sql.txt").arg(sql).toUtf8().data());
- qry = mdb.exec(sql);
- while(qry.next()){
- AlarmSet CompanyAlarm = AlarmSet(getDeviceIdxByDeviceCode(qry.value(0).toString()),qry.value(3).toString(),
- qry.value(2).toString(),16,qry.value(1).toDateTime().toTime_t(),1);
- if(nrow==0){
- // system(QString("echo '%1 %2 %3' >> /root/data.txt ").arg(webData->companys[i].CompanyCode).arg(qry.value(1).toString()).arg(qry.value(2).toString()).toUtf8().data());
- setLastAlarmSet(i,16,CompanyAlarm);
- }
- companyAlarmList.append(CompanyAlarm);
- allAlarmList.append(CompanyAlarm);
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- nrow++;
- }
- qry.clear();
- qSort(companyAlarmList.begin(),companyAlarmList.end(),compareAlarmSet);
- qSort(allAlarmList.begin(),allAlarmList.end(),compareAlarmSet);
- while(companyAlarmList.length()>10)
- companyAlarmList.removeLast();
- while(allAlarmList.length()>10)
- allAlarmList.removeLast();
- for(int j=0;j<10;j++){
- if(j<companyAlarmList.length()){
- AlarmSet alarm = companyAlarmList.at(j);
- webData->CompanyAlarm[i].alarmRec[j].DeviceIdx=alarm.DeviceIdx;
- sprintf(webData->CompanyAlarm[i].alarmRec[j].DevName,"%s",alarm.DevName.toUtf8().data());
- sprintf(webData->CompanyAlarm[i].alarmRec[j].Data,"%s",alarm.AlarmData.toUtf8().data());
- sprintf(webData->CompanyAlarm[i].alarmRec[j].Time,"%s",QDateTime::fromTime_t(alarm.AlarmTime).toString("yyyy-MM-dd HH:mm:ss").toUtf8().data());
- webData->CompanyAlarm[i].alarmRec[j].dwType = alarm.dwType;
- webData->CompanyAlarm[i].alarmRec[j].Time_T = alarm.AlarmTime;
- webData->CompanyAlarm[i].alarmRec[j].ShowFlag = 0x01;
- }else
- webData->CompanyAlarm[i].alarmRec[j].ShowFlag = 0x00;
- webData->CompanyAlarm[i].UpdateTime = UpdateTime;
- }
- }
- usleep(5000);
- }
- for(int j=0;j<10;j++){
- if(j<allAlarmList.length()){
- AlarmSet alarm = allAlarmList.at(j);
- webData->CompanyAlarm[10239].alarmRec[j].DeviceIdx = alarm.DeviceIdx;
- sprintf(webData->CompanyAlarm[10239].alarmRec[j].DevName,"%s",alarm.DevName.toUtf8().data());
- sprintf(webData->CompanyAlarm[10239].alarmRec[j].Data,"%s",alarm.AlarmData.toUtf8().data());
- sprintf(webData->CompanyAlarm[10239].alarmRec[j].Time,"%s",QDateTime::fromTime_t(alarm.AlarmTime).toString("yyyy-MM-dd HH:mm:ss").toUtf8().data());
- webData->CompanyAlarm[10239].alarmRec[j].dwType = alarm.dwType;
- webData->CompanyAlarm[10239].alarmRec[j].Time_T = alarm.AlarmTime;
- webData->CompanyAlarm[10239].alarmRec[j].ShowFlag = 0x01;
- }else
- webData->CompanyAlarm[10239].alarmRec[j].ShowFlag = 0x00;
- webData->CompanyAlarm[10239].UpdateTime = UpdateTime;
- }
- }
- void DB_SyncThread::checkAlarmStatus()
- {
- char company_code[50];
- QSqlQuery qry = mdb.exec("select company_code, device_01_count+device_03_count as dev1count, device_01_out+device_03_out as dev1out, device_01_out_confirm+device_03_out_confirm as dev1outconfirm, device_01_alarm+device_03_alarm as dev1ala, device_01_alarm_confirm+device_03_alarm_confirm as dev1alaconfirm, device_02_count, device_02_out, device_02_out_confirm, device_02_alarm, device_02_alarm_confirm, device_06_count, device_06_out, device_06_out_confirm, device_06_alarm, device_06_alarm_confirm, device_07_count, device_07_out, device_07_out_confirm, device_07_alarm, device_07_alarm_confirm, device_16_count, device_16_out, device_16_out_confirm, device_16_alarm, device_16_alarm_confirm from sp_company_sync");
- while(qry.next()){
- sprintf(company_code,"%s",qry.value(0).toString().toUtf8().data());
- if(strlen(company_code)>0){
- for(unsigned int i=0;i<10240;i++){
- if(i>=webData->CompanysCount)
- break;
- if(strcmp(company_code,webData->companys[i].CompanyCode)==0){
- webData->companys[i].subType[1].DevCount = qry.value(1).toUInt();
- webData->companys[i].subType[1].DevOutLineCount = qry.value(2).toUInt();
- webData->companys[i].subType[1].DevOutConfirmCount = qry.value(3).toUInt();
- webData->companys[i].subType[1].DevAlarmCount = qry.value(4).toUInt();
- webData->companys[i].subType[1].DevAlarmConfirmCount = qry.value(5).toUInt();
- webData->companys[i].subType[2].DevCount = qry.value(6).toUInt();
- webData->companys[i].subType[2].DevOutLineCount = qry.value(7).toUInt();
- webData->companys[i].subType[2].DevOutConfirmCount = qry.value(8).toUInt();
- webData->companys[i].subType[2].DevAlarmCount = qry.value(9).toUInt();
- webData->companys[i].subType[2].DevAlarmConfirmCount = qry.value(10).toUInt();
- webData->companys[i].subType[6].DevCount = qry.value(11).toUInt();
- webData->companys[i].subType[6].DevOutLineCount = qry.value(12).toUInt();
- webData->companys[i].subType[6].DevOutConfirmCount = qry.value(13).toUInt();
- webData->companys[i].subType[6].DevAlarmCount = qry.value(14).toUInt();
- webData->companys[i].subType[6].DevAlarmConfirmCount = qry.value(15).toUInt();
- webData->companys[i].subType[7].DevCount = qry.value(16).toUInt();
- webData->companys[i].subType[7].DevOutLineCount = qry.value(17).toUInt();
- webData->companys[i].subType[7].DevOutConfirmCount = qry.value(18).toUInt();
- webData->companys[i].subType[7].DevAlarmCount = qry.value(19).toUInt();
- webData->companys[i].subType[7].DevAlarmConfirmCount = qry.value(20).toUInt();
- webData->companys[i].subType[16].DevCount = qry.value(21).toUInt();
- webData->companys[i].subType[16].DevOutLineCount = qry.value(22).toUInt();
- webData->companys[i].subType[16].DevOutConfirmCount = qry.value(23).toUInt();
- webData->companys[i].subType[16].DevAlarmCount = qry.value(24).toUInt();
- webData->companys[i].subType[16].DevAlarmConfirmCount = qry.value(25).toUInt();
- break;
- }
- }
- }
- {
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- }
- usleep(5000);
- }
- qry.clear();
- }
- void DB_SyncThread::checkDevice()
- {
- unsigned int count = 0;
- QSqlQuery qry = mdb.exec("SELECT id, owner_code, company, dwtype, owner_name, unitinfo from sp_owner");
- while(qry.next()){
- if((webData->devices[count].dwType!=(qry.value(3).toUInt()&0xff))
- ||(QString::compare(QString::fromUtf8(webData->devices[count].DevCode),qry.value(1).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->devices[count].CompanyCode),qry.value(2).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->devices[count].DevName),qry.value(4).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->devices[count].DevInfo),qry.value(5).toString())!=0)){
- webData->devices[count].DevIdx = count&0xffffffff;
- sprintf(webData->devices[count].DevCode,"%s",qry.value(1).toString().toUtf8().data());
- sprintf(webData->devices[count].CompanyCode,"%s",qry.value(2).toString().toUtf8().data());
- webData->devices[count].dwType = qry.value(3).toUInt()&0xff;
- sprintf(webData->devices[count].DevName,"%s",qry.value(4).toString().toUtf8().data());
- sprintf(webData->devices[count].DevInfo,"%s",qry.value(5).toString().toUtf8().data());
- webData->devices[count].Enabled = 0x01;
- webData->devices[count].UpdateTime = UpdateTime;
- }
- count++;
- if(count>webData->DevicesCount)
- webData->DevicesCount = count;
- if(count>102399)
- break;
- usleep(5000);
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- }
- qry.clear();
- }
- void DB_SyncThread::checkCompany()
- {
- unsigned int count = 0;
- QSqlQuery qry = mdb.exec("select c.owner_id, c.owner_name, c.xmlx, p.username, p.phone, c.building_id, b.build_name, ifnull(concat(b.addr1,'.',b.addr2,'.',b.addr3,'.',b.address),''),ifnull(b.posistion,''),b.address from jdxf.sp_owner_company c, jdxf.sp_building b, ytIoT.ytiot_t_company_phone p where c.building_id=b.id and c.owner_id = p.owner_code");
- while(qry.next()){
- float Lng=0.0,Lat=0.0;
- QString position = qry.value(8).toString();
- if(position.length()>0){
- QStringList pos = position.split(",");
- if(pos.length()>1){
- Lng = pos.at(0).toFloat();
- Lat = pos.at(1).toFloat();
- }
- }
- if(
- // (webData->buildings[count].Lng!=Lng)
- // ||(webData->buildings[count].Lat!=Lat)
- // ||
- (QString::compare(QString::fromUtf8(webData->companys[count].CompanyCode),qry.value(0).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->companys[count].CompanyName),qry.value(1).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->companys[count].ProjectType),qry.value(2).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->companys[count].UserName),qry.value(3).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->companys[count].Phone),qry.value(4).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->buildings[count].CompanyCode),qry.value(0).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->buildings[count].BuildingCode),qry.value(5).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->buildings[count].BuildingName),qry.value(6).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->buildings[count].FullAddress),qry.value(7).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->buildings[count].Address),qry.value(9).toString())!=0)){
- sprintf(webData->companys[count].CompanyCode,"%s",qry.value(0).toString().toUtf8().data());
- sprintf(webData->companys[count].CompanyName,"%s",qry.value(1).toString().toUtf8().data());
- sprintf(webData->companys[count].ProjectType,"%s",qry.value(2).toString().toUtf8().data());
- sprintf(webData->companys[count].UserName,"%s",qry.value(3).toString().toUtf8().data());
- sprintf(webData->companys[count].Phone,"%s",qry.value(4).toString().toUtf8().data());
- sprintf(webData->buildings[count].CompanyCode,"%s",qry.value(0).toString().toUtf8().data());
- sprintf(webData->buildings[count].BuildingCode,"%s",qry.value(5).toString().toUtf8().data());
- sprintf(webData->buildings[count].BuildingName,"%s",qry.value(6).toString().toUtf8().data());
- sprintf(webData->buildings[count].FullAddress,"%s",qry.value(7).toString().toUtf8().data());
- sprintf(webData->buildings[count].Address,"%s",qry.value(9).toString().toUtf8().data());
- webData->buildings[count].Lng = Lng;
- webData->buildings[count].Lat = Lat;
- webData->companys[count].UpdateTime = UpdateTime;
- webData->buildings[count].UpdateTime = UpdateTime;
- }
- count++;
- if(count>webData->BuildingsCount)
- webData->BuildingsCount = count;
- if(count>webData->CompanysCount)
- webData->CompanysCount = count;
- if(count>webData->CompanysAlarmCount)
- webData->CompanysAlarmCount = count;
- if(count>10239)
- break;
- usleep(5000);
- {
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- }
- }
- webData->CompanysCount = count;
- webData->BuildingsCount = count;
- webData->CompanysAlarmCount = count;
- qry.clear();
- }
- void DB_SyncThread::checkUsers()
- {
- unsigned int count = 0;
- QSqlQuery qry = mdb.exec("select username, password, truename, status from sp_user order by id");
- while(qry.next()){
- if((webData->users[count].Status!=(qry.value(3).toUInt()&0xff))
- ||(QString::compare(QString::fromUtf8(webData->users[count].LoginName),qry.value(0).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->users[count].Password),qry.value(1).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->users[count].UserName),qry.value(2).toString())!=0)){
- sprintf(webData->users[count].LoginName,"%s",qry.value(0).toString().toUtf8().data());
- sprintf(webData->users[count].Password,"%s",qry.value(1).toString().toUtf8().data());
- sprintf(webData->users[count].UserName,"%s",qry.value(2).toString().toUtf8().data());
- webData->users[count].Status = qry.value(3).toUInt()&0xff;
- webData->users[count].UpdateTime = UpdateTime;
- }
- count++;
- if(count>webData->UsersCount)
- webData->UsersCount = count;
- if(count>10239)
- break;
- usleep(5000);
- {
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- }
- }
- qry.clear();
- count = 0;
- qry = mdb.exec("select agentid, owner_code from sp_owner_weibao order by id");
- while(qry.next()){
- if((QString::compare(QString::fromUtf8(webData->userCompanys[count].Loginname),qry.value(0).toString())!=0)
- ||(QString::compare(QString::fromUtf8(webData->userCompanys[count].CompanyCode),qry.value(1).toString())!=0)){
- sprintf(webData->userCompanys[count].Loginname,"%s",qry.value(0).toString().toUtf8().data());
- sprintf(webData->userCompanys[count].CompanyCode,"%s",qry.value(1).toString().toUtf8().data());
- webData->userCompanys[count].UpdateTime = UpdateTime;
- }
- count++;
- if(count>webData->UserCompanyCount)
- webData->UserCompanyCount = count;
- if(count>20479)
- break;
- usleep(5000);
- {
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- }
- }
- qry.clear();
- }
- void DB_SyncThread::run()
- {
- webShmInit();
- times = 0;
- while(1)
- {
- time_t tmp_time = time(static_cast<time_t *>(nullptr));
- ytShm->updatetime[DB_THREAD] = tmp_time;
- time_out();
- sleep(5);
- }
- }
|