1、使用cast() 和 convert() 函数实现日期格式的转换
语法格式:
convert( 表达式,数据类型 )
cast( 表达式 as 数据类型 )
可转换的类型有 字符串char、日期date、时间time、日期时间datetime、浮点型decimal、整数signed、无符号整数unsigned。
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⑴0⑶0 04:29:44 |
+———————+
2、使用date_format()函数实现日期格式的转换
date_format()函数可以以区别的格式显示日期/时间数据,可以实现日期转换成字符串。
语法格式:
date_format(date,format)
date为合法的日期,format为规定日期/时间的输出格式。
可使用的格式有:
格式 |
描写 |
%a |
缩写星期名 |
%b |
缩写月名 |
%c |
月,数值 |
%D |
带有英文前缀的月中的天 |
%d |
月的天,数值(00⑶1) |
%e |
月的天,数值(0⑶1) |
%f |
微秒 |
%H |
小时 (00⑵3) |
%h |
小时 (01⑴2) |
%I |
小时 (01⑴2) |
%i |
分钟,数值(00⑸9) |
%j |
年的天 (001⑶66) |
%k |
小时 (0⑵3) |
%l |
小时 (1⑴2) |
%M |
月名 |
%m |
月,数值(00⑴2) |
%p |
AM 或 PM |
%r |
时间,12-小时(hh:mm:ss AM 或 PM) |
%S |
秒(00⑸9) |
%s |
秒(00⑸9) |
%T |
时间, 24-小时 (hh:mm:ss) |
%U |
周 (00⑸3) 星期日是一周的第一天 |
%u |
周 (00⑸3) 星期一是一周的第一天 |
%V |
周 (01⑸3) 星期日是一周的第一天,与 %X 使用 |
%v |
周 (01⑸3) 星期一是一周的第一天,与 %x 使用 |
%W |
星期名 |
%w |
周的天 (0=星期日, 6=星期六) |
%X |
年,其中的星期日是周的第一天,4 位,与 %V 使用 |
%x |
年,其中的星期一是周的第一天,4 位,与 %v 使用 |
%Y |
年,4 位 |
%y |
年,2 位 |
示例1:时间类型转换成字符串类型
mysql> select date_format(now(),’%Y-%m-%d’);
+——————————-+
| date_format(now(),’%Y-%m-%d’) |
+——————————-+
| 2020⑴0⑶0 |
+——————————-+
示例2:从学生表 ‘student’ 中查询前2人现在的年龄。
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)
mysql> select str_to_date(‘2020⑴0⑶′,’%Y-%m-%d’);
+————————————-+
| str_to_date(‘2020⑴0⑶′,’%Y-%m-%d’) |
+————————————-+
| 2020⑴0-03 |
+————————————-+
mysql> select str_to_date(‘2020⑴0⑶′,’%Y’);
+——————————-+
| str_to_date(‘2020⑴0⑶′,’%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日期类型转换内容请搜索之前的文章或继续浏览下面的相关文章希望大家以后多多支持!
文章来源:丸子建站
文章标题:合适新手的mysql日期类型转换实例教程
https://www.wanzijz.com/view/59298.html