Re: Views, indices and pg_dump

Поиск
Список
Период
Сортировка
От Richard Huxton
Тема Re: Views, indices and pg_dump
Дата
Msg-id 009101c0b696$5229e1c0$1001a8c0@archonet.com
обсуждение исходный текст
Ответ на Views, indices and pg_dump  (Zak McGregor <zak@mighty.co.za>)
Ответы Re: Views, indices and pg_dump
Список pgsql-general
From: "Zak McGregor" <zak@mighty.co.za>

> Hi all
>
> Thanks to everyone for this great forum, and for Postgres!
>
> I have a couple of questions:
>
> I have a smallish table which I join on another (smaller) table. I have
> created a view for this purpose, thinking it would save on overhead.
> The view also incorporates some calculated fields. However, when I do an
> EXPLAIN SELECT * FROM my_view it shows sequential scans on both tables and
> no use of any indices (I've created them on the view and the two other
> tables). It seems the view does the join on the fly. If so, will using a
> view speed up queries? Also, how do I make it use the indices for queries?

OK - a view is nothing more than a pre-built query. It is useful for
ease-of-use and controlling which users can see which parts of your
database. It isn't going to gain you anything in performance.

If the EXPLAIN shows sequential scans, you'll need to look into the costs
listed for each stage of the query and how many rows PG thinks will be
returned. There are some items on explain in the performance-tips section of
the user manual, Bruce's book (link on www.postgresql.org) and in my
PostgreSQL notes (techdocs.postgresql.org)

If you want assistance with the explain please post the view definition, its
table definitions along with the explain.

> Another, slightly unrelated question: Why does pg_dump dump the view as a
> normal table?

Mine dumps as a CREATE VIEW statement - can you provide an example (with
which version of PG you are using).

HTH

- Richard Huxton


В списке pgsql-general по дате отправления:

Предыдущее
От: Alexander Lohse
Дата:
Сообщение: Re: Hi
Следующее
От: "Eric G. Miller"
Дата:
Сообщение: Re: records zapped to null