我想创建一个 MySQL 查询来查找子网表中存在的最长匹配(以四点格式的给定 IP 地址)。
最终,我想创建一个LEFT JOIN
将显示一个表中的每个四点 IP 地址与另一个表中最长的匹配项相连接的一个表。我不想创建任何临时表或将其构建为嵌套查询。
我有点像 MySQL 新手,但我在想的是这样的:
SELECT `ip_address`
LEFT JOIN ON
SELECT `subnet_id`
FROM `subnets_table`
WHERE (`maximum_ip_value` - `minimum_ip_value`) =
LEAST(<list of subnet intervals>)
WHERE INET_ATON(<given ip address>) > `minimum_ip_value`
AND INET_ATON(<given ip address>) < `maximum_ip_value`;
这样minimum_ip_value
和maximum_ip_value
是给定子网中可能的最低和最高十进制格式的 IP 地址 - 例如,对于子网 172.16.0.0/16:
minimum_ip_value = 2886729728 (or 172.16.0.0)
maximum_ip_value = 2886795263 (or 172.16.255.255)
并且<list of subnet intervals>
包含介于和subnets_table
之间的所有间隔<given ip address>
minimum_ip_value
maximum_ip_value
如果一个以上的区间包含<given ip address>
,那么最小的区间(即最小的子网,或最具体和“最长”的匹配)被加入。
最终,我真正想要的是subnet_id
与该间隔对应的值。
所以我的问题是:
1) 我可以使用带有任意数量参数的 LEAST() 函数吗?我想比较 的每一行,或者更具体地说,比较每一行在和subnets_table
之间的间隔,并选择最小的间隔。minimum_ip_value
maximum_ip_value
2) 我可以在LEFT JOIN
查询中执行所有这些计算吗?我可以接受任何快速、封装并避免重复查询相同数据的建议。
我想知道这是否甚至可以在单个查询中执行(即,不为每个 IP 地址查询子网表),但我不知道足以排除它。请告知这看起来是否行不通,所以我可以尝试另一个角度。
谢谢。