日期处理含有T,Z等特殊的日期处理



public class DateUtil {
/**
     * All Dates are normalized to UTC, it is up the client code to convert to the appropriate TimeZone.
     */
    public static final TimeZone UTC;


    /**
     * @see <a href="http://en.wikipedia.org/wiki/ISO_8601#Combined_date_and_time_representations">Combined Date and Time Representations</a>
     */
    public static final String ISO_8601_24H_FULL_FORMAT = "yyyy-MM-dd'T'HH:mm:ss.SSSXXX";


    /**
     * 0001-01-01T00:00:00.000Z
     */
    public static final Date BEGINNING_OF_TIME;


    /**
     * 292278994-08-17T07:12:55.807Z
     */
    public static final Date END_OF_TIME;


    static
    {
        UTC = TimeZone.getTimeZone("UTC");
        TimeZone.setDefault(UTC);
        final Calendar c = new GregorianCalendar(UTC);
        c.set(1, 0, 1, 0, 0, 0);
        c.set(Calendar.MILLISECOND, 0);
        BEGINNING_OF_TIME = c.getTime();
        c.setTime(new Date(Long.MAX_VALUE));
        END_OF_TIME = c.getTime();
    }


    public static void main(String[] args) throws Exception
    {


        final SimpleDateFormat sdf = new SimpleDateFormat(ISO_8601_24H_FULL_FORMAT);
        sdf.setTimeZone(UTC);
        System.out.println("sdf.format(BEGINNING_OF_TIME) = " + sdf.format(BEGINNING_OF_TIME));
        System.out.println("sdf.format(END_OF_TIME) = " + sdf.format(END_OF_TIME));
        System.out.println("sdf.format(new Date()) = " + sdf.format(new Date()));
        System.out.println("sdf.parse(\"2015-04-28T14:23:38.521Z\") = " + sdf.parse("2015-04-28T14:23:38.521Z"));
        System.out.println("sdf.parse(\"0001-01-01T00:00:00.000Z\") = " + sdf.parse("0001-01-01T00:00:00.000Z"));
        System.out.println("sdf.parse(\"292278994-08-17T07:12:55.807Z\") = " + sdf.parse("292278994-08-17T07:12:55.807Z"));
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值