[英]MySQL - order by string date
我有一个加入到我的帖子中的元值,即日期。 我希望只能获取将来的帖子,但是此日期是varchar,格式为
dd-mm-yyyy
这是我到目前为止尝试过的,但似乎无法正常工作
select `posts`.*, `storage_varchars`.`meta_value`
from `posts` left join `storage_varchars` on
`posts`.`id` = `storage_varchars`.`post_id`
where `parent_id` = 20 and
DATE(storage_varchars.meta_value) >= NOW()
order by DATE(storage_varchars.meta_value) asc
使用STR_TO_DATE()函数:
尝试这个:
SELECT p.*, s.meta_value
FROM posts p
LEFT JOIN storage_varchars s ON p.id = s.post_id
WHERE parent_id = 20 AND STR_TO_DATE(s.meta_value, '%d-%m-%Y') >= CURRENT_DATE()
ORDER BY STR_TO_DATE(s.meta_value, '%d-%m-%Y') ASC;
尝试这个
select `posts`.*, `storage_varchars`.`meta_value`
from `posts` left join `storage_varchars` on
`posts`.`id` = `storage_varchars`.`post_id`
where `parent_id` = 20 and
STR_TO_DATE(storage_varchars.meta_value, '%d %M %Y') >= NOW()
order by STR_TO_DATE(storage_varchars.meta_value, '%d %M %Y') DESC
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.