Postgres Check if IP (inet) is IN a list of IP Ranges
Asked Answered
I

1

17

I want to check if an IP exists in a range of ranges, eg: SELECT * FROM ip_address WHERE ip IN (<list of ip ranges>)

Postgresql documentation states to use the << operator to check if an IP is contained within a single IP Range, eg: inet '192.168.1.5' << inet '192.168.1/24', but I'm not sure how to use it on a list of ranges without having to construct an OR chain of <<'s.

Iceblink answered 24/7, 2014 at 21:13 Comment(0)
P
21
select inet '192.168.1.5' << any (array['192.168.1/24', '10/8']::inet[]);
 ?column? 
----------
 t

http://www.postgresql.org/docs/current/static/functions-comparisons.html#AEN18486

Phylum answered 24/7, 2014 at 21:21 Comment(1)
Note that if the list can also contain exact non-range matches like '192.168.1.1', you should use <<= (contains or equals) rather than << (contains). This caught me out.Whittling

© 2022 - 2024 — McMap. All rights reserved.