首页 > 解决方案 > 在 SQL 之间选择日期。其中日期的格式为 dd/mm/yyyy 并且是一个字符串

问题描述

在我的 sql 表中,我有一个格式为“DD/MM/YYYY”的字符串。如何选择日期范围?例如table.date BETWEEN '01/01/2019' and '31/10/2019'?谢谢。

标签: mysqlsqlpostgresql

解决方案


您应该使用正确的数据类型存储日期。您必须转换日期,这通常会影响性能。

在 Postgres 中,您可以执行以下操作:

to_date(table.date, 'DD/MM/YYYY') >= '2019-01-01' AND
to_date(table.date, 'DD/MM/YYYY') < '2020-01-01'

在 MySQL 中,这将是:

date_format(table.date, '%d/%m/%Y') >= '2019-01-01' AND
date_format(table.date, '%d/%m/%Y') < '2020-01-01' 

在任一数据库中,您还可以使用字符串操作,因为您想要全年:

table.date LIKE '%/2019'

推荐阅读