经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
适合新手的mysql日期类型转换实例教程
来源:jb51  时间:2022/8/16 15:27:37  对本文有异议

1、使用cast() 和 convert() 函数实现日期格式的转换

语法格式:

    convert( 表达式,数据类型 )

    cast( 表达式 as 数据类型 )

可转换的类型有 字符串char、日期date、时间time、日期时间datetime、浮点型decimal、整数signed、无符号整数unsigned。

  1. mysql> select cast(now() as signed);
  2. +-----------------------+
  3. | cast(now() as signed) |
  4. +-----------------------+
  5. | 20201030042922 |
  6. +-----------------------+
  7. 1 row in set (0.00 sec)
  8.  
  9. mysql> select convert(now(),signed);
  10. +-----------------------+
  11. | convert(now(),signed) |
  12. +-----------------------+
  13. | 20201030042933 |
  14. +-----------------------+
  15. 1 row in set (0.00 sec)
  16.  
  17. mysql> select cast(now() as char);
  18. +---------------------+
  19. | cast(now() as char) |
  20. +---------------------+
  21. | 2020-10-30 04:29:44 |
  22. +---------------------+

2、使用date_format()函数实现日期格式的转换

date_format()函数可以以不同的格式显示日期/时间数据,可以实现日期转换成字符串。

语法格式:

date_format(date,format)

date为合法的日期,format为规定日期/时间的输出格式。

可以使用的格式有:

格式描述
%a缩写星期名
%b缩写月名
%c月,数值
%D带有英文前缀的月中的天
%d月的天,数值(00-31)
%e月的天,数值(0-31)
%f微秒
%H小时 (00-23)
%h小时 (01-12)
%I小时 (01-12)
%i分钟,数值(00-59)
%j年的天 (001-366)
%k小时 (0-23)
%l小时 (1-12)
%M月名
%m月,数值(00-12)
%pAM 或 PM
%r时间,12-小时(hh:mm:ss AM 或 PM)
%S秒(00-59)
%s秒(00-59)
%T时间, 24-小时 (hh:mm:ss)
%U周 (00-53) 星期日是一周的第一天
%u周 (00-53) 星期一是一周的第一天
%V周 (01-53) 星期日是一周的第一天,与 %X 使用
%v周 (01-53) 星期一是一周的第一天,与 %x 使用
%W星期名
%w周的天 (0=星期日, 6=星期六)
%X年,其中的星期日是周的第一天,4 位,与 %V 使用
%x年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y年,4 位
%y年,2 位

示例1:时间类型转换成字符串类型

  1. mysql> select date_format(now(),'%Y-%m-%d');
  2. +-------------------------------+
  3. | date_format(now(),'%Y-%m-%d') |
  4. +-------------------------------+
  5. | 2020-10-30 |
  6. +-------------------------------+

示例2:从学生表 ‘student’ 中查询前2人现在的年龄。

  1. mysql> select * from student limit 2;
  2. +------------+-----------+-----+------------+-----------------------+---------+
  3. | Sid | Sname | Sex | Brithdate | Specialty | AScores |
  4. +------------+-----------+-----+------------+-----------------------+---------+
  5. | 2011216001 | 赵成刚 | | 1992-05-05 | 计算机应用技术 | 405.0 |
  6. | 2011216002 | 李婧 | | 1992-01-06 | 计算机应用技术 | 395.5 |
  7. +------------+-----------+-----+------------+-----------------------+---------+
  8.  
  9. mysql> select sname,
  10. -> convert(date_format(now(),'%Y'),signed)-convert(date_format(Brithdate,'%Y'),signed) as '年龄'
  11. -> from student
  12. -> limit 2;
  13. +-----------+--------+
  14. | sname | 年龄 |
  15. +-----------+--------+
  16. | 赵成刚 | 28 |
  17. | 李婧 | 28 |
  18. +-----------+--------+

3、使用str_to_date()函数实现字符串类型转换日期类型

str_to_date()函数可以将时间格式的字符串按照所指定的显示格式(format)转换为不同的时间类型。

语法格式:

str_to_date(date,format)

  1. mysql> select str_to_date('2020-10-3','%Y-%m-%d');
  2. +-------------------------------------+
  3. | str_to_date('2020-10-3','%Y-%m-%d') |
  4. +-------------------------------------+
  5. | 2020-10-03 |
  6. +-------------------------------------+
  7.  
  8. mysql> select str_to_date('2020-10-3','%Y');
  9. +-------------------------------+
  10. | str_to_date('2020-10-3','%Y') |
  11. +-------------------------------+
  12. | 2020-00-00 |
  13. +-------------------------------+
  14.  
  15. mysql> select str_to_date('10:11','%H:%i:%S');
  16. +---------------------------------+
  17. | str_to_date('10:11','%H:%i:%S') |
  18. +---------------------------------+
  19. | 10:11:00 |
  20. +---------------------------------+

把字符串转换为日期时间需要注意以下几点:

待转换字符串中只能出现数字,否则返回结果为 null;

如果格式字符串仅包含日期,则待转字符串至少需要 8 位数字,转换时默认前四位是年份,中间两位是月份,最后两位是日期,格式字符串无需使用 - 区分日期各部分,结果会自动用 - 拼接日期各个部分;

转换后日期时间必须有效,否则返回结果为 null;

如果被转字符串超出 8 位且格式字符串中无时间格式,则自动取前 8 位转换为日期;

格式字符串可包含时间格式,格式字符串无需使用 : 区分时间各部分,结果中的时间部分会自动用 : 连接各个部分。

str_to_date() 函数的用法和 date_format() 基本一致,只是输出数据的类型不同,前提都需要熟悉输出格式,参照date_format() 。

总结

到此这篇关于mysql日期类型转换的文章就介绍到这了,更多相关mysql日期类型转换内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号