我需要獲得查詢的特定結果......我相信解決方案是同一個表的自聯接......但它并沒有像我期望的那樣作業。
一點背景知識:“時間范圍”串列示時間增量資料集。“15m”是 15 分鐘資料點的資料集。“1h”是 1 小時資料點的資料集。
這是表的內容:
priceID | price_time | timeframe | price | thing
1 | 2020-01-01 10:00:00 | "15m" | 150 | 0
2 | 2020-01-01 10:15:00 | "15m" | 155 | 1
3 | 2020-01-01 10:30:00 | "15m" | 140 | 0
4 | 2020-01-01 10:45:00 | "15m" | 123 | 1
5 | 2020-01-01 11:00:00 | "15m" | 159 | 0
6 | 2020-01-01 10:00:00 | "1h" | 150 | 1
7 | 2020-01-01 11:00:00 | "1h" | 159 | 0
這是我需要的記錄集。我想要每個唯一的 price_time 一行,以及所有其他列的唯一列,按時間范圍值分組。
price_time | timeframe_15m | timeframe_1h | price_15m | price_1h | thing_15m | thing_1h
2020-01-01 10:00:00 | "15m" | "1h" | 150 | 150 | 0 | 1
2020-01-01 10:15:00 | "15m" | NULL | 155 | NULL | 1 | NULL
2020-01-01 10:30:00 | "15m" | NULL | 140 | NULL | 0 | NULL
2020-01-01 10:45:00 | "15m" | NULL | 123 | NULL | 1 | NULL
2020-01-01 11:00:00 | "15m" | "1h" | 159 | 150 | 0 | 0
這是我認為可行的方法,但沒有。
SELECT
c.price_time
,c.timeframe AS price_time_15m
,c.price AS price_15m
,c.thing AS thing_15m
,o.timeframe AS timeframe_1h
,o.price AS price_1h
,o.thing AS thing_1h
FROM tbl_prices c LEFT OUTER JOIN tbl_prices o ON c.price_time = o.price_time
WHERE c.timeframe = '15m'
AND o.timeframe = '1h'
我已經在這上面花了很長時間并且被正式卡住了!任何幫助將不勝感激!
uj5u.com熱心網友回復:
使用條件聚合:
SELECT price_time,
MAX(CASE WHEN timeframe = '"15m"' THEN timeframe END) timeframe_15m,
MAX(CASE WHEN timeframe = '"1h"' THEN timeframe END) timeframe_1h,
MAX(CASE WHEN timeframe = '"15m"' THEN price END) price_15m,
MAX(CASE WHEN timeframe = '"1h"' THEN price END) price_1h,
MAX(CASE WHEN timeframe = '"15m"' THEN thing END) thing_15m,
MAX(CASE WHEN timeframe = '"1h"' THEN thing END) thing_1h
FROM tbl_prices
GROUP BY price_time;
請參閱演示。
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/333999.html
