适合新手的mysql日期类型转换实例教程
1、使用cast() 和 convert() 函数实现日期格式的转换
语法格式:
convert( 表达式,数据类型 )
cast( 表达式 as 数据类型 )
可转换的类型有 字符串char、日期date、时间time、日期时间datetime、浮点型decimal、整数signed、无符号整数unsigned。
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | mysql> select cast (now() as signed); + -----------------------+ | cast (now() as signed) | + -----------------------+ | 20201030042922 | + -----------------------+ 1 row in set (0.00 sec) mysql> select convert (now(),signed); + -----------------------+ | convert (now(),signed) | + -----------------------+ | 20201030042933 | + -----------------------+ 1 row in set (0.00 sec) mysql> select cast (now() as char ); + ---------------------+ | cast (now() as char ) | + ---------------------+ | 2020-10-30 04:29:44 | + ---------------------+ |
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) |
%p | AM 或 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 2 3 4 5 6 | mysql> select date_format(now(), '%Y-%m-%d' ); + -------------------------------+ | date_format(now(), '%Y-%m-%d' ) | + -------------------------------+ | 2020-10-30 | + -------------------------------+ |
示例2:从学生表 ‘student’ 中查询前2人现在的年龄。
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | mysql> select * from student limit 2; + ------------+-----------+-----+------------+-----------------------+---------+ | Sid | Sname | Sex | Brithdate | Specialty | AScores | + ------------+-----------+-----+------------+-----------------------+---------+ | 2011216001 | 赵成刚 | 男 | 1992-05-05 | 计算机应用技术 | 405.0 | | 2011216002 | 李婧 | 女 | 1992-01-06 | 计算机应用技术 | 395.5 | + ------------+-----------+-----+------------+-----------------------+---------+ mysql> select sname, -> convert (date_format(now(), '%Y' ),signed)- convert (date_format(Brithdate, '%Y' ),signed) as '年龄' -> from student -> limit 2; + -----------+--------+ | sname | 年龄 | + -----------+--------+ | 赵成刚 | 28 | | 李婧 | 28 | + -----------+--------+ |
3、使用str_to_date()函数实现字符串类型转换日期类型
str_to_date()函数可以将时间格式的字符串按照所指定的显示格式(format)转换为不同的时间类型。
语法格式:
?str_to_date(date,format)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | mysql> select str_to_date( '2020-10-3' , '%Y-%m-%d' ); + -------------------------------------+ | str_to_date( '2020-10-3' , '%Y-%m-%d' ) | + -------------------------------------+ | 2020-10-03 | + -------------------------------------+ mysql> select str_to_date( '2020-10-3' , '%Y' ); + -------------------------------+ | str_to_date( '2020-10-3' , '%Y' ) | + -------------------------------+ | 2020-00-00 | + -------------------------------+ mysql> select str_to_date( '10:11' , '%H:%i:%S' ); + ---------------------------------+ | str_to_date( '10:11' , '%H:%i:%S' ) | + ---------------------------------+ | 10:11:00 | + ---------------------------------+ |
把字符串转换为日期时间需要注意以下几点:
待转换字符串中只能出现数字,否则返回结果为 null;
如果格式字符串仅包含日期,则待转字符串至少需要 8 位数字,转换时默认前四位是年份,中间两位是月份,最后两位是日期,格式字符串无需使用 - 区分日期各部分,结果会自动用 - 拼接日期各个部分;
转换后日期时间必须有效,否则返回结果为 null;
如果被转字符串超出 8 位且格式字符串中无时间格式,则自动取前 8 位转换为日期;
格式字符串可包含时间格式,格式字符串无需使用 : 区分时间各部分,结果中的时间部分会自动用 : 连接各个部分。
str_to_date() 函数的用法和 date_format() 基本一致,只是输出数据的类型不同,前提都需要熟悉输出格式,参照date_format() 。
总结
到此这篇关于mysql日期类型转换的文章就介绍到这了,更多相关mysql日期类型转换内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/supahero/article/details/109446197
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。