按结果出现的半径数将结果按ST_DWith排序

时间:2019-01-09 16:09:17

标签: sql postgresql aggregate postgis rank

我有一个现有客户表和另一个潜在客户表。我想返回一个潜在客户的列表,该列表按出现的现有购买者的半径数排序。

每个现有客户在潜在客户表中有很多行,并且给定现有客户周围的半径可能包含多个潜在客户。我想返回一个按潜在客户的现有客户半径计数排序的潜在客户列表。

SELECT pur.contact_id AS purchaser, count(pot.*) AS nearby_potential_customers 
FROM purchasers_geocoded pur, potential_customers_geocoded pot 
WHERE ST_DWithin(pur.geom,pot.geom,1000)
GROUP BY purchaser;

有人对如何进行有任何建议吗?

编辑:

在一些帮助下,我编写了此查询,该查询似乎可以完成工作,但我现在正在验证。

WITH prequalified_leads_table AS (
   SELECT *
   FROM nearby_potential_customers
   WHERE market_val > 80000
   AND   market_val < 120000
   )
, proximate_to_existing AS (
   SELECT pot.prop_id AS prequalified_leads
   FROM purchasers_geocoded pur, prequalified_leads_table pot
   WHERE ST_DWithin(pot.geom,pur.geom,100)
  )
SELECT prequalified_leads, count(prequalified_leads)
FROM proximate_to_existing
GROUP BY prequalified_leads
ORDER BY count(*) DESC;

1 个答案:

答案 0 :(得分:2)

  

我想返回一个按潜在客户的现有客户半径计数排序的潜在客户列表。

您的查询尝试了与您的陈述相反的情况,将潜在客户数计算为现有客户数。 反过来,并添加一些调整后:

SELECT pot.contact_id AS potential_customer
     , rank() OVER (ORDER BY pur.nearby_customers DESC
                           , pot.contact_id) AS rnk
     , pur.nearby_customers 
FROM   potential_customers_geocoded pot
LEFT   JOIN LATERAL (
   SELECT count(*) AS nearby_customers 
   FROM   purchasers_geocoded pur
   WHERE  ST_DWithin(pur.geom, pot.geom, 1000)
   ) pur ON true
ORDER  BY 2;

我建议使用LEFT JOIN LATERAL ... ON true进行子查询以获取计数。应该利用您无疑拥有的空间索引:

CREATE INDEX ON purchasers_geocoded USING gist (geom);

因此,结果中保留有0个附近客户的行-您的原始联接样式将排除这些行。相关:

然后在外部查询中ORDER BY生成nearby_customers(不是: nearby_potential_customers )。

不清楚您是否要添加实际的rank。如果是,请使用window function rank()。在达到排名时,我确定了排名,并使用附加的ORDER BY表达式:pot.contact_id打破了联系。否则,对等方将以任意顺序返回,每次执行时都可以更改。

ORDER BY 2是“按第二列输出顺序”的缩写语法。参见:

相关: