前言:数据库中时间一般是long 型时间 或者存的是 string , ;类似:1657695512793 例:2022-07-12 14:28:05
我们使用时,有时想用字符串,有时还有 long 型;需要转换;QT本身给我们提供了方便的API 

先看两个API

uint toTime_t() const;

函数 这个函数返回当前自1970-01-01 00:00:00经过了多少秒,返回值为一个UINT类型。
fromTime_t(uint seconds);

函数则可以将距1970-01-01 00:00:00 的秒数转换为QDateTime,,seconds 表示的是距 1970-01-01 00:00:00 的秒数。

首先 Qt 获取系统时间

QDateTime local(QDateTime::currentDateTime());
QString localTime = local.toString("yyyy-MM-dd:hh:mm:ss");
qDebug() << localTime;

输出结果:"2022-07-13 22:25:58"

1. string to long

//string 例:2022-07-12 14:28:05

QDateTime dateTime = QDateTime::fromString("2022-07-12 14:28:05","yyyy-MM-dd hh:mm:ss");

dateTime.setTimeSpec(Qt::LocalTime);

uint secondsLocal= dateTime.toTime_t();

qDebug() << "local second ="+QString::number(secondsLocal);

2. long to string;

注意:

UTC时间同本地时间关系:

           UTC +时间差=本地时间

 时间差根据时区定,东边为正,西边为负,如北京东八区,时间差0800,8小时。如果UTC时间是 2020-02-25 00:00:00 那么北京时间就是 20202-02-25 08:00:00。
 

QDateTime dateTime0 = QDateTime::fromTime_t(1657695512793);

dateTime0.setTimeSpec(Qt::LocalTime);

qDebug() <<"local date:"+dateTime0.toString("yyyy-MM-dd hh:mm:ss");

dateTime0.setTimeSpec(Qt::UTC);

qDebug() <<"UTC date:"+dateTime0.toString("yyyy-MM-dd hh:mm:ss");