首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >重构SQL脚本

重构SQL脚本
EN

Stack Overflow用户
提问于 2012-02-24 04:21:48
回答 2查看 123关注 0票数 1

我已经编写了这个SQL脚本:

代码语言:javascript
复制
    DECLARE @location geography  
    DECLARE @radius int  

    SET @location = (SELECT Location FROM Hydrants WHERE HydrantId = 2)  
    SET @radius = (SELECT Radius FROM Hydrants WHERE HydrantId = 2)  

    SELECT * 
    FROM Sites 
    WHERE @location.STDistance(location) < @radius 
    ORDER BY SiteId ASC  

我这样做是为了重构它。

代码语言:javascript
复制
SELECT * 
FROM Sites, Hydrants 
Inner Join Hydrants.Location.STDistance(Sites.Location) < Hydrants.Radius  
WHERE Hydrants.HydrantId = 2 
ORDER BY Sites.SiteId ASC;  

但是没有运气。

任何建议都将受到欢迎。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-02-24 04:44:07

我不知道SQL2008的地理特性,但当看到您的代码时,以下内容可能会起作用:

代码语言:javascript
复制
SELECT
    Sites.*
FROM Sites
INNER JOIN Hydrants
    ON Hydrants.Location.STDistance(Sites.location) < Hydrants.Radius
WHERE Hydrants.HydrantId = 2 
ORDER BY Sites.SiteId ASC;
票数 2
EN

Stack Overflow用户

发布于 2012-02-24 04:43:29

我从来没有使用过地理类型,但这是连接的正确语法,它的作用与原始查询相同;

代码语言:javascript
复制
SELECT Sites.*
FROM Sites 
JOIN Hydrants 
  ON Hydrants.Location.STDistance(Sites.Location) < Hydrants.Radius  
WHERE Hydrants.HydrantId = 2 
ORDER BY Sites.SiteId ASC; 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9420628

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档