在 Vertica 中计算所有股票的移动平均线
Calculating the moving average in Vertica for all stocks
我有一只股票table例如:
CREATE TABLE Ticks
(
ts TIMESTAMP,
Stock varchar(10),
Bid float
);
INSERT INTO Ticks VALUES('2011-07-12 10:23:54', 'abc', 10.12);
INSERT INTO Ticks VALUES('2011-07-12 10:23:58', 'abc', 10.34);
INSERT INTO Ticks VALUES('2011-07-12 10:23:59', 'abc', 10.75);
INSERT INTO Ticks VALUES('2011-07-12 10:25:15', 'abc', 11.98);
INSERT INTO Ticks VALUES('2011-07-12 10:25:16', 'abc');
INSERT INTO Ticks VALUES('2011-07-12 10:25:22', 'xyz', 45.16);
INSERT INTO Ticks VALUES('2011-07-12 10:25:27', 'xyz', 49.33);
INSERT INTO Ticks VALUES('2011-07-12 10:31:12', 'xyz', 65.25);
INSERT INTO Ticks VALUES('2011-07-12 10:31:15', 'xyz');
COMMIT;
我想在 Vertica 中通过一次查询计算所有股票的移动平均线。
这是只针对一只股票的方法(根据 Vertica 网站):
SELECT
ts, bid,
AVG(bid) OVER (ORDER BY ts
RANGE BETWEEN INTERVAL '40 seconds' PRECEDING AND CURRENT ROW)
FROM
ticks
WHERE
stock = 'abc'
GROUP BY
bid, ts
ORDER BY
ts;
输出:
ts | bid | ?column?
---------------------+-------+------------------
2011-07-12 10:23:54 | 10.12 | 10.12
2011-07-12 10:23:58 | 10.34 | 10.23
2011-07-12 10:23:59 | 10.75 | 10.4033333333333
2011-07-12 10:25:15 | 11.98 | 11.98
2011-07-12 10:25:16 | | 11.98
(5 rows)
DROP TABLE Ticks CASCADE;
如果我尝试select所有库存:
SELECT
stock, ts, bid,
AVG(bid) OVER (ORDER BY ts
RANGE BETWEEN INTERVAL '40 seconds' PRECEDING AND CURRENT ROW)
FROM
ticks
GROUP BY
stock, bid, ts
ORDER BY
stock, ts;
我得到了错误的结果。
我该如何解决?
在您对 AVG()
的调用中添加一个 PARTITION BY
子句:
SELECT ts, bid,
AVG(bid) OVER (PARTITION BY stock ORDER BY ts
RANGE BETWEEN INTERVAL '40 seconds' PRECEDING AND
CURRENT ROW)
FROM ticks
ORDER BY ts;
我有一只股票table例如:
CREATE TABLE Ticks
(
ts TIMESTAMP,
Stock varchar(10),
Bid float
);
INSERT INTO Ticks VALUES('2011-07-12 10:23:54', 'abc', 10.12);
INSERT INTO Ticks VALUES('2011-07-12 10:23:58', 'abc', 10.34);
INSERT INTO Ticks VALUES('2011-07-12 10:23:59', 'abc', 10.75);
INSERT INTO Ticks VALUES('2011-07-12 10:25:15', 'abc', 11.98);
INSERT INTO Ticks VALUES('2011-07-12 10:25:16', 'abc');
INSERT INTO Ticks VALUES('2011-07-12 10:25:22', 'xyz', 45.16);
INSERT INTO Ticks VALUES('2011-07-12 10:25:27', 'xyz', 49.33);
INSERT INTO Ticks VALUES('2011-07-12 10:31:12', 'xyz', 65.25);
INSERT INTO Ticks VALUES('2011-07-12 10:31:15', 'xyz');
COMMIT;
我想在 Vertica 中通过一次查询计算所有股票的移动平均线。
这是只针对一只股票的方法(根据 Vertica 网站):
SELECT
ts, bid,
AVG(bid) OVER (ORDER BY ts
RANGE BETWEEN INTERVAL '40 seconds' PRECEDING AND CURRENT ROW)
FROM
ticks
WHERE
stock = 'abc'
GROUP BY
bid, ts
ORDER BY
ts;
输出:
ts | bid | ?column?
---------------------+-------+------------------
2011-07-12 10:23:54 | 10.12 | 10.12
2011-07-12 10:23:58 | 10.34 | 10.23
2011-07-12 10:23:59 | 10.75 | 10.4033333333333
2011-07-12 10:25:15 | 11.98 | 11.98
2011-07-12 10:25:16 | | 11.98
(5 rows)
DROP TABLE Ticks CASCADE;
如果我尝试select所有库存:
SELECT
stock, ts, bid,
AVG(bid) OVER (ORDER BY ts
RANGE BETWEEN INTERVAL '40 seconds' PRECEDING AND CURRENT ROW)
FROM
ticks
GROUP BY
stock, bid, ts
ORDER BY
stock, ts;
我得到了错误的结果。
我该如何解决?
在您对 AVG()
的调用中添加一个 PARTITION BY
子句:
SELECT ts, bid,
AVG(bid) OVER (PARTITION BY stock ORDER BY ts
RANGE BETWEEN INTERVAL '40 seconds' PRECEDING AND
CURRENT ROW)
FROM ticks
ORDER BY ts;