js日期格式mysql_mysql中取出的时间格式不正确

ps:

最终采用了一楼推荐的momentjs进行转换,

希望帮到后来人,此坑完结.

mysql中存储的数据类型是datetime

45d05759ea7e98b7839821f69c1ad9be.png

select出来都是utc时间 格式如下:

2019-07-08T03:38:27.000Z

因为utc 2019-07-08T03:38:27.000Z格式不是北京时间且格式不是需要的,

所以取出我对数据进行了转换 ,转换方法如下:

function formatUTC(utc_datetime) {

// 转为正常的时间格式 年-月-日 时:分:秒

var T_pos = utc_datetime.indexOf('T');

var Z_pos = utc_datetime.indexOf('Z');

var year_month_day = utc_datetime.substr(0, T_pos);

var hour_minute_second = utc_datetime.substr(T_pos + 1, Z_pos - T_pos - 1);

var new_datetime = year_month_day + " " + hour_minute_second; // 2017-03-31 08:02:06

// 处理成为时间戳

timestamp = new Date(Date.parse(new_datetime));

timestamp = timestamp.getTime();

timestamp = timestamp / 1000;

// 增加8个小时,北京时间比utc时间多八个时区

var timestamp = timestamp + 8 * 60 * 60;

// 时间戳转为时间

var beijing_datetime = new Date(parseInt(timestamp) * 1000).toLocaleString().replace(/年|月/g, "-").replace(/日/g, " ");

return beijing_datetime;

}

本地开发环境后台返回前台得到的数据都是正确的格式 YYYY-MM-DD hh-mm-ss 如: 1999-10-10 08:30:10 ,字符串

但是,

项目上传到centOS服务器上之后,取出的时间都变成了 7/8/2019, 7:01:12 AM (字符串)

这并不是我想要的,排查原因,看到浏览器端得到的数据就已经是7/8/2019, 7:01:12 AM类型了,不是前端显示问题,

说明还是服务器除了问题,但是不知道哪里出了问题?为什么本地mac开发环境没有异常呢?

如果解决不了的话这种日期格式怎么转换,求指教!

ps:

最终采用了一楼推荐的momentjs进行转换,

希望帮到后来人,此坑完结.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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字母的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值