Between Symmetric in PostgreSQL
PostgreSQL's between construct allows you to make a comparison between
two values (numbers, timestamps, etc.).
> select * from generate_series(1,10) as numbers(a)
where numbers.a between 3 and 6;
a
---
3
4
5
6
If you supply an empty range by using the larger of the two values first, an empty set will result.
> select * from generate_series(1,10) as numbers(a)
where numbers.a between 6 and 3;
a
---
Tacking symmetric onto the between construct is one way to avoid this
issue.
> select * from generate_series(1,10) as numbers(a)
where numbers.a between symmetric 6 and 3;
a
---
3
4
5
6
TweetBETWEEN SYMMETRIC is the same as BETWEEN except there is no requirement that the argument to the left of AND be less than or equal to the argument on the right. If it is not, those two arguments are automatically swapped, so that a nonempty range is always implied.