在做一些通讯的程序的时候,发现直接使用时间如yyyymmddhhmmss来发给对方,其实并不是唯一的,有可能是你这一时间那瞬间里面已经处理了几件事,所以并不能代表这一瞬间的一件事。于是我对时间做了处理,用数据库的一个字段记录时间,然后每一次读取最大的时间记录数,使用时间的时候,给它自加1,然后再使用时间,这样就可以代表一个时间点处理一个唯一的事情。
double getTimeNo(){
double result;
AnsiString time;
AnsiString strSql="select max(TimeNo) TimeNo from TTS_Interface";
TADOQuery *query = DM->ADOQuery_Comm;
query->SQL->Clear();
query->SQL->Add(strSql);
query->Open();
query->First();
if (!query->Eof)
{
time = query->FieldByName("TimeNo")->AsString;
if(time=="")
time=Now().FormatString("yyyymmddhhmmss");
}
result= time.ToDouble()+1;
return result;
}
AnsiString timeNo=FloatToStr(getTimeNo());