mysql 时间戳 转int_MySQL时间戳相互转换

mysql将时间戳转成常用时间格式

在mysql中,一个时间字段的存储类型是int(11),怎么转化成字符类型,比方存储为13270655222,需要转化为yyyy -mm-dd的形式。

使用 FROM_UNIXTIME函数,具体如下:

FROM_UNIXTIME(unix_timestamp,format)

返回表示 Unix 时间标记的一个字符串,根据format字符串格式化。format可以包含与DATE_FORMAT()函数列出的条目同样的修饰符。

根据format字符串格式化date值。下列修饰符可以被用在format字符串中: %M 月名字(January……December)

%W 星期名字(Sunday……Saturday)

%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)

%Y 年, 数字, 4 位

%y 年, 数字, 2 位

%a 缩写的星期名字(Sun……Sat)

%d 月份中的天数, 数字(00……31)

%e 月份中的天数, 数字(0……31)

%m 月, 数字(01……12)

%c 月, 数字(1……12)

%b 缩写的月份名字(Jan……Dec)

%j 一年中的天数(001……366)

%H 小时(00……23)

%k 小时(0……23)

%h 小时(01……12)

%I 小时(01……12)

%l 小时(1……12)

%i 分钟, 数字(00……59)

%r 时间,12 小时(hh:mm:ss [AP]M)

%T 时间,24 小时(hh:mm:ss)

%S 秒(00……59)

%s 秒(00……59)

%p AM或PM

%w 一个星期中的天数(0=Sunday ……6=Saturday )

%U 星期(0……52), 这里星期天是星期的第一天

%u 星期(0……52), 这里星期一是星期的第一天

%% 一个文字“%”。

例如:

SELECT FROM_UNIXTIME(1422720000, '%Y-%m-%d %T')

输出为:

2015-02-01 00:00:00

如何将一个日期类型转换成时间戳呢?其实很简单,只需要用 日期转换为UNIX时间戳用函数:UNIX_TIMESTAMP()。

使用 UNIX_TIMESTAMP函数,具体如下:

SELECT UNIX_TIMESTAMP('2006-11-04 12:23:00');

例如:

SELECT UNIX_TIMESTAMP('2006-11-04 12:23:00');

输出为:

1162614180

另外

NOW() //当前时间

SYSDATE()//当前时间CURRENT_TIMESTAMP以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格式返回当前的日期和时间,取决于函数是在一个字符串还是在数字的上下文被使用。

mysql> selectNOW();-> '1997-12-15 23:50:26'mysql> select NOW() + 0;-> 19971215235026

SEC_TO_TIME(seconds)

返回seconds参数,变换成小时、分钟和秒,值以'HH:MM:SS'或HHMMSS格式化,取决于函数是在一个字符串还是在数字上下文中被使用。

mysql> select SEC_TO_TIME(2378);-> '00:39:38'mysql> select SEC_TO_TIME(2378) + 0;-> 3938

TIME_TO_SEC(time)

返回time参数,转换成秒。

mysql> select TIME_TO_SEC('22:23:00');-> 80580mysql> select TIME_TO_SEC('00:39:38');-> 2378

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL 中的时间戳是指从1970年1月1日00:00:00 UTC(协调世界时)开始经过的秒数,通常也被称为 Unix 时间戳。如果你想将时间戳转换MySQL 中的日期时间格式,可以使用 FROM_UNIXTIME() 函数。这个函数接受一个时间戳参数,并将其转换MySQL 中的日期时间格式。 例如,假设你有一个名为 `mytable` 的表,其中包含一个名为 `timestamp` 的时间戳列,你可以使用以下 SQL 语句将时间戳转换为日期时间格式: ``` SELECT FROM_UNIXTIME(timestamp) FROM mytable; ``` 这将返回一个包含时间戳转换后日期时间值的结果集。你也可以使用 DATE_FORMAT() 函数将日期时间值格式化为你想要的日期时间字符串格式。例如,以下 SQL 语句将时间戳转换为格式为 "YYYY-MM-DD HH:MI:SS" 的日期时间字符串: ``` SELECT DATE_FORMAT(FROM_UNIXTIME(timestamp), '%Y-%m-%d %H:%i:%s') FROM mytable; ``` 希望这能够帮助你! ### 回答2: 在MySQL中,可以使用FROM_UNIXTIME函数将UNIX时间戳转换为对应的日期时间。 UNIX时间戳是从1970年1月1日00:00:00以来经过的秒数。要将时间戳转换为日期时间,可以使用以下语法: ```sql SELECT FROM_UNIXTIME(timestamp) ``` 其中,timestamp是要转换时间戳。FROM_UNIXTIME函数将返回一个格式为YYYY-MM-DD HH:MM:SS的日期时间字符串。 以下是一个例子: 假设有一个名为orders的表,其中包含一个名为created_time的列,它存储了订单创建的UNIX时间戳。 表结构如下: ```sql CREATE TABLE orders ( id INT AUTO_INCREMENT PRIMARY KEY, created_time INT ); ``` 现在,我们要将created_time列的时间戳转换为日期时间并进行查询,可以使用以下语句: ```sql SELECT id, FROM_UNIXTIME(created_time) AS creation_date FROM orders; ``` 运行该查询后,将以以下格式显示结果: ``` id | creation_date ------+------------------- 1 | 2022-01-01 09:30:00 2 | 2022-01-02 14:45:30 3 | 2022-01-03 18:20:15 ``` 通过使用FROM_UNIXTIME函数,我们可以轻松地将UNIX时间戳转换为易于理解的日期时间格式。 ### 回答3: 在MySQL中,时间戳转换为时间可以使用FROM_UNIXTIME()函数。该函数将Unix时间戳(以秒为单转换MySQL的日期和时间格式。 语法如下: FROM_UNIXTIME(unix_timestamp) 其中,unix_timestamp为Unix时间戳。 举例说明: 假设存在一个名为timestamp_table的表,其中有一个名为timestamp_column的列存储了时间戳数据。 要将时间戳转换为时间,可以使用以下SQL查询语句: SELECT FROM_UNIXTIME(timestamp_column) FROM timestamp_table; 这将返回一个包含转换后时间的结果集。如果还需要指定日期和时间的格式,则可以使用DATE_FORMAT()函数对结果进行格式化。 例如,如果要将时间格式化为YYYY-MM-DD HH:MM:SS的形式,可以使用以下查询: SELECT DATE_FORMAT(FROM_UNIXTIME(timestamp_column), '%Y-%m-%d %H:%i:%s') FROM timestamp_table; 这样会返回按给定格式格式化后的时间。 总之,在MySQL中,使用FROM_UNIXTIME()函数可以将时间戳转换为日期和时间格式,并可以选择进行格式化以满足具体需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值