商城首页欢迎来到中国正版软件门户

您的位置:首页 >如何在MySQL中使用VARCHAR类型进行日期比较和排序操作?

如何在MySQL中使用VARCHAR类型进行日期比较和排序操作?

  发布于2023-04-30 阅读(0)

扫一扫,手机访问

在mysql使用过程中,日期一般都是以datetime、timestamp等格式进行存储的,但有时会因为特殊的需求或历史原因,日期的存储格式是varchar,那么我们该如何处理这个varchar格式的日期数据呢?

使用函数:STR_TO_DATE(str, format)

STR_TO_DATE(str, format)函数是DATE_FORMAT()函数的反函数。它需要一个字符串str和一个格式字符串格式。STR_TO_DATE()返回一个DATETIME值,如果格式字符串包含日期和时间部分,或如果字符串只包含日期或时间的部分返回日期或时间值。

下面举个案例进行说明。

比如我现在有一张会员表,表的结构如下所示:

如何在MySQL中使用VARCHAR类型进行日期比较和排序操作?

我在表中造了如下几条数据:

如何在MySQL中使用VARCHAR类型进行日期比较和排序操作?

现在,如果我需要从中挑选出2018年8月份注册的所有会员,并按注册时间进行排序,那么要怎么做呢?这里给出一个参考:

SELECT id,nickname,createtime 
FROM member
WHERE str_to_date(createtime, '%Y-%m-%d') BETWEEN str_to_date('2018-08-01', '%Y-%m-%d') AND str_to_date('2018-08-31', '%Y-%m-%d')
ORDER BY str_to_date(createtime, '%Y-%m-%d')

执行结果如下:

如何在MySQL中使用VARCHAR类型进行日期比较和排序操作?

本文转载于:https://www.yisu.com/zixun/618784.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注