我有一个丑陋的问题...
sum(CASE
WHEN effective_from_date < '2011-05-24' THEN (rate * (effective_to_date - '2011-05-24' + 1))
WHEN effective_to_date > '2011-05-28' THEN (rate * ('2011-05-28' - effective_from_date + 1))
ELSE (rate * (effective_to_date - effective_from_date + 1))
END
) as price_cal_rate
FROM calendar_event
WHERE property_rid = (SELECT rid FROM property WHERE web_id = 'T28314') AND
((effective_from_date BETWEEN '2011-05-24' AND '2011-05-28') OR (effective_to_date BETWEEN '2011-05-24' AND '2011-05-28'))
AND
NOT EXISTS (
SELECT days_diff FROM (
SELECT ((effective_from_date - lag(effective_to_date) OVER (PARTITION BY NULL ORDER BY effective_from_date ASC))) AS days_diff, effective_from_date, effective_to_date
FROM calendar_event
WHERE property_rid = (SELECT rid FROM property WHERE web_id = 'T28314') AND
((effective_from_date BETWEEN '2011-05-26' AND '2011-05-28') OR (effective_to_date BETWEEN '2011-05-26' AND '2011-05-28'))
) AS t WHERE COALESCE(days_diff, 0) > 1
) AND EXISTS (select * from (
select min(effective_from_date) as min_date, max(effective_to_date) as max_date FROM calendar_event
WHERE property_rid = (SELECT rid FROM property WHERE web_id = 'T28314') AND
((effective_from_date BETWEEN '2011-05-24' AND '2011-05-28') OR (effective_to_date BETWEEN '2011-05-24' AND '2011-05-28'))
) as max_min WHERE min_date <= '2011-05-24' and max_date >= '2011-05-28')查询正在计算range....the查询为fine...but的日期的比率查询中有许多重复...我想知道是否有一种很好的方法将此子查询的结果存储在某个地方
FROM calendar_event
WHERE property_rid = (SELECT rid FROM property WHERE web_id = 'T28314')
AND
((effective_from_date BETWEEN '2011-05-24' AND '2011-05-28') OR (effective_to_date BETWEEN '2011-05-24' AND '2011-05-28')) 并在我的整个查询中使用它....
发布于 2011-05-08 13:46:52
您可以按照"mu is too short“的建议使用临时表,但是如果您只需要一个"main”查询中的结果,并且您使用的是PostgreSQL 8.4或更高版本,那么您也可以使用with queries
https://stackoverflow.com/questions/5925131
复制相似问题