我有以下表,其中id是记录的唯一标识符(但表D不能有它):
CREATE TABLE A (id int, a1 int, name text, a3 int);
INSERT INTO A VALUES (1, 100, 'Annie', 3);
CREATE TABLE B (id int, b1 int, b2 int);
CREATE TABLE C (id int, c1 int, c2 int);
CREATE TABLE D (d1 int, name text);
INSERT INTO D VALUES(2000, 'Annie');
INSERT INTO D VALUES(2050, 'Annie');
我需要从上面的表- b1、c2和count(d1)中找到与id=1的对象相关的信息。id
是查询的唯一已知信息(我们不知道它是关于“Annie”的,只知道它是关于一个id=1的对象)。我知道我可以做这样的事情:
SELECT A.id, A.name, B.b1, C.c2, dd.total
FROM A
LEFT JOIN B on A.id=B.id
LEFT JOIN C on A.id=C.id
LEFT JOIN (SELECT count(d1) total, name FROM D GROUP BY name) dd ON (dd.name = A.name)
WHERE A.id=1
我可以优化这个SQL吗?当表变得很大时,子查询SELECT count(d1) total, d2 FROM D GROUP BY d2
不会大大降低查询的速度吗?
1条答案
按热度按时间1qczuiv01#
您可以用实体化视图替换子查询。参见Postgres Materialized View Auto Refresh