时间不代表唯一的标识

在做一些通讯的程序的时候,发现直接使用时间如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());

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值