求解决办法!

lifeng40401 2010-07-14 04:04:47
需求描述:
使用VC做一个从日志文件中读取信息写入到数据库中的程序

问题说明
当前我考虑每一小时作一次日志入库程序,存在的问题是同一时段的
日志文件按大小切割成好几个文件,文件名如
******_100714_00_001.log
******_100714_00_002.log
******_100714_00_003.log
由于文件名没有以创建的时分秒来命名,这将导致的情况是某一时段
我要读哪个日志文件其实是不知道的

我想到的解决办法:
起一个线程,不断去扫描日志目录,形成一张文件名与文件创建时间
的对应表,通过文件的创建时间来找到某一时段的日志,但是怎么去扫
描日志目录,如何去实现大家以前有没有做过?另外针对上述问题大家有没有
更好的解决办法?
...全文
43 点赞 收藏 3
写回复
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
stonewater 2010-07-14
跟时间有什么关系吗
反正是要入库,你只有判断把还没有入库的文件入库就是了,
当然了你实在要按照顺序那就判断文件的创建时间
回复
zhanshen2891 2010-07-14
记录一下上次读到哪里不就可以了么??
回复
InitialJ 2010-07-14
不能读文件的创建时间吗
HANDLE   hFile;   
WIN32_FIND_DATA wfd;
SYSTEMTIME systime;
FILETIME localtime;
char stime[32]; //输出时间
memset(&wfd, 0, sizeof(wfd));

if((hFile=FindFirstFile("D:\\邮件头.pdf", &wfd))==INVALID_HANDLE_VALUE)
{
char c[2];
DWORD dw=GetLastError();
wsprintf(c, "%d", dw);
AfxMessageBox(c);
return ;//失败
}
//ok,转换时间
FileTimeToLocalFileTime(&wfd.ftLastWriteTime,&localtime);
FileTimeToSystemTime(&localtime,&systime);
sprintf(stime,"%4d-%02d-%02d %02d:%02d:%02d",
systime.wYear,systime.wMonth,systime.wDay,systime.wHour,
systime.wMinute,systime.wSecond);
回复
发动态
发帖子
VC/MFC
创建于2007-09-28

1.5w+

社区成员

VC/MFC相关问题讨论
申请成为版主
社区公告
暂无公告