我的表里有一个finish_time的字段,类型为timestamp,现在我要查询某一天内的所有记录,请问SQL语句应该怎么写。以前时间戳类型我都是用的int类型,这次变了timestamp不会弄了,望大神帮忙~
我的表里有一个finish_time的字段,类型为timestamp,现在我要查询某一天内的所有记录,请问SQL语句应该怎么写。以前时间戳类型我都是用的int类型,这次变了timestamp不会弄了,望大神帮忙~
MySQL TIMESTAMP | ||
---|---|---|
列类型 | 显示格式 | |
TIMESTAMP(14) | YYYYMMDDHHMMSS | |
TIMESTAMP(12) | YYMMDDHHMMSS | |
TIMESTAMP(10) | YYMMDDHHMM | |
TIMESTAMP(8) | YYYYMMDD | |
TIMESTAMP(6) | YYMMDD | |
TIMESTAMP(4) | YYMM | |
TIMESTAMP(2) | YY |
追求运行速度的话,sql中少用函数(函数可能会影响索引的使用):
select * table where finish_time between '20160408000000' and '20160408240000'
省事的可以用函数,类似于一楼。
1 回答2.4k 阅读✓ 已解决
1 回答2.3k 阅读✓ 已解决
3 回答2.3k 阅读
2 回答950 阅读
可以考虑用以下SQL文
如果你是在psql中直接执行SQL文,那么你可以直接这么执行(假设你要查询的是2016年3月8日的记录):
另,楼下@dackel 回答的不错,我给的方法因为对finish_time列进行了显示类型转换(调用CAST函数),所以如果你的表定义中已经对finish_time定义了索引,那么这个索引的效果就发挥不出来了。
不过 @dackel 给的解决方法的SQL文不适用于PostgreSQL,PG中的TIMESTAMP类型不是这么用的, 所以我对于该方法补充一个PG版本的SQL文(仍然是以查询2016年3月8日为例):
注意,相对于 @dackel 的答案,我给出的BETWEEN条件是 BETWEEN TIMESTAMP'2016-03-08 00:00:00' AND TIMESTAMP'2016-03-08 23:59:59', 这是因为在PG中, TIMESTAMP '2016-03-08 24:00:00' 会被自动转为 TIMESTAMP '2016-03-09 00:00:00'。 而且,这里还需要注意的是,关于这个BETWEEN的上界,对于列定义为TIMESTAMP(0)时,上界为TIMESTAMP'2016-03-08 23:59:59'; 但如果列定义为TIMESTAMP(6)时,上界应为TIMESTAMP'2016-03-08 23:59:59.999999'。这是因为TIMESTAMP定义的精度不一样。