1

我正在尝试执行 sql 查询以获取介于两者之间的子句中的数据。问题是我不知道如何查询谁可以有差异子句取决于参数中的值。

是)我有的:

SELECT TableA.DNSName, TableA.IPAddressStr, TableB.OSName
FROM TableB 
INNER JOIN TableA 
  ON TableB.AssetOSID = TableA.AssetOSID 
CROSS JOIN IPRanges
WHERE (IpRanges.ConfigID = @configID)
  (Assets.IPAddress BETWEEN IPRanges.StartIPAddress AND IPRanges.EndIPAddress)

什么样的表:

IpRanges:
ConfigID|StartIpAdress|EndIPAdress <br>
1|23|53
1|56|87
3|90|134
3|560|600 
3|780|800 

如您所见,每个 configID 上 ipRanges 的数量发生了变化,并且表 ipRanges 和表 TableA 之间没有链接。

提前致谢。

4

2 回答 2

1

在这种情况下,您需要使用带有having子句的聚合——因为您希望所有条件都为真。

这个想法是计算范围为真的次数并将它们与总计数进行比较:

SELECT TableA.DNSName, TableA.IPAddressStr, TableB.OSName
FROM TableB INNER JOIN
     TableA
     ON TableB.AssetOSID = TableA.AssetOSID CROSS JOIN
     IPRanges
WHERE (IpRanges.ConfigID = @configID)
group by TableA.DNSName, TableA.IPAddressStr, TableB.OSName
having sum(case when Assets.IPAddress BETWEEN IPRanges.StartIPAddress AND IPRanges.EndIPAddress) then 1 else 0 end) =
       count(*);

如果只有一行需要匹配,则使用此having子句:

having sum(case when Assets.IPAddress BETWEEN IPRanges.StartIPAddress AND IPRanges.EndIPAddress) then 1 else 0 end) > 0
于 2013-05-24T14:17:32.777 回答
1

不完全确定您在这里追求什么。一些示例结果以及其他表中的示例数据会有所帮助..

但这可能很接近。

SELECT TableA.DNSName, TableA.IPAddressStr, TableB.OSName 
FROM TableB 
INNER JOIN TableA 
  ON TableB.AssetOSID = TableA.AssetOSID 
INNER JOIN IPRanges 
  ON (IpRanges.ConfigID = @configID)
 AND (Assets.IPAddress BETWEEN IPRanges.StartIPAddress AND IPRanges.EndIPAddress)
于 2013-05-24T14:17:52.610 回答