FILETIME, SYSTEMTIME 与 time_t 相互转换

FILETIME, SYSTEMTIME 与 time_t 相互转换 

#####SYSTEMTIME 与 FILETIME相互转换#####
可以使用系统函数
FileTimeToSystemTime(&ftcreate,&stcreate);  

参数:
(lpFileTime As FILETIME, lpSystemTime As SYSTEMTIME)
说明
根据一个FILETIME结构的内容,装载一个SYSTEMTIME结构
返回值
Long,非零表示成功,零表示失败。会设置GetLastError
参数表
参数 类型及说明
lpFileTime FILETIME,包含了文件时间的一个结构
lpSystemTime SYSTEMTIME,用于装载系统时间信息的一个结构

#####SYSTEMTIME 与 time_t相互转换#####
void TimetToSystemTime( time_t t, LPSYSTEMTIME pst )
{
   FILETIME ft;

   LONGLONG ll = Int32x32To64(t, 10000000) + 116444736000000000;
   ft.dwLowDateTime = (DWORD) ll;
   ft.dwHighDateTime = (DWORD)(ll >> 32);

   FileTimeToSystemTime( &ft, pst );
}

void SystemTimeToTimet( SYSTEMTIME st, time_t *pt )
{
   FILETIME ft;
   SystemTimeToFileTime( &st, &ft );

   LONGLONG ll;

   ULARGE_INTEGER ui;
   ui.LowPart = ft.dwLowDateTime;
   ui.HighPart = ft.dwHighDateTime;

   ll = (ft.dwHighDateTime << 32) + ft.dwLowDateTime;

   *pt = (DWORD)((LONGLONG)(ui.QuadPart - 116444736000000000) / 10000000);
}

 #### FileTimeToTime_t ####

void  FileTimeToTime_t(  FILETIME  ft,  time_t  *t  )  
{  
           LONGLONG  ll;  
 
           ULARGE_INTEGER            ui;  
           ui.LowPart            =  ft.dwLowDateTime;  
           ui.HighPart            =  ft.dwHighDateTime;  
 
           ll            =  ft.dwHighDateTime  <<  32  +  ft.dwLowDateTime;  
 
           *t            =  ((LONGLONG)(ui.QuadPart  -  116444736000000000)  /  10000000);  

 
在Windows下使用C++将char转换为DateTime并写入数据库,可以使用以下步骤: 1. 将char转换为SYSTEMTIME 可以使用Windows API函数`MultiByteToWideChar`将char字符串转换为Unicode字符串,然后使用`swscanf`函数将Unicode字符串转换为SYSTEMTIME结构体。 示例代码: ```c++ char strTime[20] = "2022-01-01 12:00:00"; // 待转换的时间字符串 SYSTEMTIME st; memset(&st, 0, sizeof(st)); // 初始化SYSTEMTIME结构体 wchar_t wstrTime[20]; MultiByteToWideChar(CP_ACP, 0, strTime, -1, wstrTime, 20); swscanf(wstrTime, L"%d-%d-%d %d:%d:%d", &st.wYear, &st.wMonth, &st.wDay, &st.wHour, &st.wMinute, &st.wSecond); ``` 2. 将SYSTEMTIME转换FILETIME 可以使用Windows API函数`SystemTimeToFileTime`将SYSTEMTIME转换FILETIME。 示例代码: ```c++ FILETIME ft; SystemTimeToFileTime(&st, &ft); ``` 3. 将FILETIME转换为SQL_TIMESTAMP_STRUCT 可以使用Windows API函数`FileTimeToSystemTime`将FILETIME转换为SYSTEMTIME,然后将SYSTEMTIME的成员赋值给SQL_TIMESTAMP_STRUCT结构体。 示例代码: ```c++ SQL_TIMESTAMP_STRUCT sqlTime; FILETIME localFt; FileTimeToLocalFileTime(&ft, &localFt); SYSTEMTIME localSt; FileTimeToSystemTime(&localFt, &localSt); sqlTime.year = localSt.wYear; sqlTime.month = localSt.wMonth; sqlTime.day = localSt.wDay; sqlTime.hour = localSt.wHour; sqlTime.minute = localSt.wMinute; sqlTime.second = localSt.wSecond; sqlTime.fraction = 0; ``` 4. 将SQL_TIMESTAMP_STRUCT写入数据库 使用ODBC API函数将SQL_TIMESTAMP_STRUCT写入数据库即可。具体操作可以参考ODBC API的文档。 示例代码: ```c++ SQL_TIMESTAMP_STRUCT sqlTime; // 将sqlTime赋值为转换后的时间结构体 // 使用ODBC API打开数据库连接 SQLHSTMT stmt; SQLAllocHandle(SQL_HANDLE_STMT, conn, &stmt); SQLPrepare(stmt, (SQLWCHAR*)L"INSERT INTO mytable (time_field) VALUES (?)", SQL_NTS); SQLBindParameter(stmt, 1, SQL_PARAM_INPUT, SQL_C_TIMESTAMP, SQL_TIMESTAMP, 19, 0, &sqlTime, 0, NULL); SQLExecute(stmt); SQLFreeHandle(SQL_HANDLE_STMT, stmt); // 使用ODBC API关闭数据库连接 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值