我正在尝试执行一个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之间没有链接。
提前谢谢。
发布于 2013-05-24 22:17:53
不太清楚你在这里想要什么..一些样本结果以及来自其他表的样本数据将会有所帮助。
但这可能已经很接近了。
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-24 22:17:33
在这种情况下,您需要使用带有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) > 0https://stackoverflow.com/questions/16736933
复制相似问题