时间格式2020-01-13T16:00:00.000Z中的T和Z分别表示什么,如何处理

T表示分隔符,Z表示的是UTC。
UTC:世界标准时间,在标准时间上加上8小时,即东八区时间,也就是北京时间。

举例   

北京时间:2020-01-14 00:00:00对应的国际标准时间格式为:2020-01-13T16:00:00.000Z

 

String dateTime = "2020-01-13T16:00:00.000Z";
dateTime = dateTime.replace("Z", " UTC");
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS Z");
SimpleDateFormat defaultFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
try {
    Date time = format.parse(dateTime);
    String result = defaultFormat.format(time);
    System.out.println(result);
} catch (Exception e) {
    e.printStackTrace();
}

// 输出结果:2020-01-14 00:00:00

 

 

  • 66
    点赞
  • 83
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
### 回答1: 这个问题通常是由于日期格式转换导致的。在MySQL日期时间格式默认是"YYYY-MM-DD HH:MM:SS"格式,而在JSON日期时间格式通常采用ISO 8601标准,即"YYYY-MM-DDTHH:MM:SSZ"格式。 因此,当你从MySQL数据库取出dateTime类型的数据时,其格式可能为"YYYY-MM-DD HH:MM:SS",但在页面上显示时,你需要将其转换为ISO 8601标准的日期格式。你可以使用PHP的date()函数对日期进行格式,例如: ``` $date = date('Y-m-d\TH:i:s\Z', strtotime($datetime)); ``` 其,$datetime是从MySQL取出的日期时间字符串,date()函数将其转换为ISO 8601标准的日期字符串。 如果你使用的是JavaScript,可以使用toLocaleString()函数将日期时间对象转换为ISO 8601标准的日期字符串,例如: ``` var date = new Date(datetime); var isoDate = date.toLocaleString('sv', { timeZone: 'UTC' }); ``` 这样,你就可以将MySQL取出的dateTime类型的数据转换为ISO 8601标准的日期格式,避免了页面显示日期后面有T时间后面000Z的问题。 ### 回答2: 当MySQL取出的dateTime在页面显示时含有"T"和"000Z"的字符,这是因为在存储和传输过程时间格式采用ISO 8601标准格式,即"YYYY-MM-DDTHH:MM:SS.000Z"。其,"T"表示时间日期的分隔符,"Z"表示时区的标识。 要处理这个问题,可以使用字符串处理函数或日期格式函数将其转换为更可读的形式。以下是两种常见的处理方法: 方法一:使用MySQL的内置函数 可以使用DATE_FORMAT函数对dateTime进行格式。例如,使用"%Y-%m-%d %H:%i:%s"将其转换为"YYYY-MM-DD HH:MM:SS"的格式。示例代码如下: ``` SELECT DATE_FORMAT(dateTime, '%Y-%m-%d %H:%i:%s') AS formattedDateTime FROM tableName; ``` 这样就可以得到不带"T"和"000Z"的日期时间字符串。 方法二:在页面使用JavaScript处理 在页面的JavaScript代码,可以使用Date对象对这个日期字符串进行处理并格式为需要的形式。示例代码如下: ```javascript var dateTimeString = "YYYY-MM-DDTHH:MM:SS.000Z"; // 替换为实际的dateTime字符串 var dateTime = new Date(dateTimeString); var formattedDateTime = dateTime.toLocaleString(); // 可根据需要选择合适的格式方法 console.log(formattedDateTime); ``` 这样就可以在浏览器的控制台输出格式后的日期时间信息,在页面显示时也可根据具体需求进行二次处理。 以上是处理MySQL取出的dateTime显示问题的两种常见方法,具体选择哪种方法取决于具体情况和使用环境的要求。 ### 回答3: MySQL的dateTime字段在页面上显示时,日期后面有字母T,时间后面有000Z是因为MySQL默认使用ISO 8601标准格式表示日期时间,T表示日期时间的分隔符,Z表示ISO 8601的零时区。 要处理这个问题,可以使用MySQL的DATE_FORMAT函数将dateTime字段格式为想要的日期字符串。比如想要显示为"YYYY-MM-DD HH:MM:SS"的格式,可以使用以下SQL语句: SELECT DATE_FORMAT(dateTime, '%Y-%m-%d %H:%i:%s') AS formattedDateTime FROM tableName; 其,dateTime是数据库表的dateTime字段名,tableName是需要查询的表名。通过使用DATE_FORMAT函数,可以将日期时间格式为指定的字符串形式。 另外,如果你是在PHP等后端语言处理MySQL的查询结果,也可以在代码使用date函数将取出的日期时间格式为想要的格式。比如使用PHP的date函数: $date = date("Y-m-d H:i:s", strtotime($row['dateTime'])); 其,$row['dateTime']是MySQL查询结果取出的dateTime字段,strtotime函数用于将字符串时间转换为时间戳,然后再使用date函数将时间戳格式为指定的日期字符串形式。 无论是在SQL查询使用DATE_FORMAT函数,还是在后端语言使用date函数,都可以将MySQL取出的dateTime字段的日期时间格式为自己想要的形式,避免显示T和Z字母的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值