我有一个现有客户表和另一个潜在客户表。我想返回一个潜在客户的列表,该列表按出现的现有购买者的半径数排序。
每个现有客户在潜在客户表中有很多行,并且给定现有客户周围的半径可能包含多个潜在客户。我想返回一个按潜在客户的现有客户半径计数排序的潜在客户列表。
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;
答案 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
是“按第二列输出顺序”的缩写语法。参见:
相关: