Re: Merging large volumes of data

Поиск
Список
Период
Сортировка
От Andreas Kostyrka
Тема Re: Merging large volumes of data
Дата
Msg-id 463F2D42.4020709@kostyrka.org
обсуждение исходный текст
Ответ на Merging large volumes of data  ("Ambrus Wagner (IJ/ETH)" <ambrus.wagner@ericsson.com>)
Ответы Re: Merging large volumes of data  (Gregory Stark <stark@enterprisedb.com>)
Re: Merging large volumes of data  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-performance
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

I think you'll have to stick with doing your sorting (or merging) in
your client. Don't think that PG recognizes the fact it's just a merge step.

Andreas

Ambrus Wagner (IJ/ETH) wrote:
> Dear All,
>
> I have several tables containing data sorted by 2 keys (neither are keys in db terms (not unique), however). I would
liketo retrieve all rows from all tables sorted by the same keys, essentially merging the contents of the tables
together.While I am completely aware of sort order not being a (fundamental) property of an RDBMS table, I am also
awareof indices and clustering (in fact, data is inserted into the tables into the correct order, and not consequently
modifiedin any way). I have a union query like this one: 
>
> select a,b,c,d,e from table1 union all
> select a,b,c,d,e from table2 union all
> etc...
> select a,b,c,d,e from tablen order by a,b;
>
> Is there a way to prevent PostgreSQL from doing a full sort on the result set after the unions have been completed?
Evenif I write 
>
> (select a,b,c,d,e from table1 order by a,b) union all
> (select a,b,c,d,e from table2 order by a,b)  union all
> etc...
> (select a,b,c,d,e from tablen order by a,b)  order by a,b;
>
> PostgreSQL does not seem to realise (maybe it should not be able to do this trick anyway) that the last "order by"
clauseis merely a final merge step on the ordered data sets. 
>
> Is there a workaround for this within PostgreSQL (another type of query, parameter tuning, stored procedure,
anything)or should I use my back-up plan of making separate queries and merging the results in the target language? 
>
> Thanks a lot,
> Ambrus
>
> --
> Wagner, Ambrus (IJ/ETH/GBD)
> Tool Designer
> GSDC Hungary
>
> Location: Science Park, A2 40 008
> Phone: +36 1 439 5282
>
> ---------------------------(end of broadcast)---------------------------
> TIP 1: if posting/reading through Usenet, please send an appropriate
>        subscribe-nomail command to majordomo@postgresql.org so that your
>        message can get through to the mailing list cleanly
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.2 (GNU/Linux)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org

iD8DBQFGPy1CHJdudm4KnO0RAuKlAKCbYu2G/MYfmX9gAlSxkzA6KB4A+QCeIlAT
USxhGD5XL7oGlIh+i2rVyN4=
=APcb
-----END PGP SIGNATURE-----

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

Предыдущее
От: "Ambrus Wagner (IJ/ETH)"
Дата:
Сообщение: Merging large volumes of data
Следующее
От: Gregory Stark
Дата:
Сообщение: Re: Merging large volumes of data