postgresql – 如何在Postgres中的inet字段上使用LIKE

我需要执行以下查询:

SELECT * FROM users WHERE ip LIKE '88.99.%';

问题是inet数据类型似乎不支持通配符(至少不是我在前面的查询中使用它们的方式).

我想知道的是,在指定LIKE过滤器之前将字段转换为字符串是否是明智之举? (另一方面,即使方法本身有效,这可能会减慢整个查询的速度.)

最佳答案
使用子网运算符进行此类查询. ’88 .99.0.0 / 16’应该这样做:

SELECT * FROM users WHERE ip << inet '88.99.0.0/16';

转载注明原文:postgresql – 如何在Postgres中的inet字段上使用LIKE - 代码日志