首页 > 解决方案 > PostgreSQL - 获取所有具有最小值最大值的行

问题描述

我有一个 PostgreSQL 表,我在表中有一个 bigint 类型的 unix_time 列。

当向表中添加新行时,时间戳将添加到 unix_time 列。

我正忙着编写一个 Python 脚本来提取时间 A 和时间 B 之间的所有行,我当前的解决方案是使用 while 循环遍历表中从第一行到最后一行的每一行。

有没有更有效的方法来做到这一点?

有没有办法让我只选择值在给定范围内的特定行 - 或值大于或等于给定整数的行?

标签: sqlpython-3.xpostgresqldatetimewhere-clause

解决方案


您将描述一个where子句:

select *
from mytable
where unix_time >= $1 and unix_time < $2

$1$2是查询的参数,代表您要过滤的间隔的范围。

您可能想根据实际情况调整不等式;这使用半开区间,这是一种广泛使用的解决方案。如果你想要一个包含两边的区间,你也可以使用between

where unix_time between $1 and $2

推荐阅读