greigwise <greigwise@xxxxxxxxxxx> writes: > So, I decided to try an experiment. I wrote 2 queries as follows: > 1 ) select pg_sleep(100) ; > 2 ) with q (s1, s2) as (select pg_sleep(100), 1) > select * from q where s2 in ( 1, <about 28 MB worth of comma > delimited numbers>) > > It looks to me like the connection running the big query is using about 2GB > more memory than the other one. I could see why it might use *some* more > (like 28MB more?), but 2GB more seems excessive. Don't hold your breath waiting for that to get better. Depending on what I assume about the widths of your numbers, you've got something like 3 million Const parse nodes in that query, so the system is eating something like 600-700 bytes per Const, which is not all that many copies because one Const node plus List overhead is probably 100 bytes on a 64-bit server. OK, it's not exactly frugal perhaps, but it would not be hard to get to that at all if you're running the query in a way that requires keeping a plancache entry for it. It would take significant work (and probably some performance sacrifices) to make much of a dent in the space consumption, and even if we put in the work, I'd only expect to be able to dent it a bit --- an order-of-magnitude reduction is not in the cards. Queries with that many parse elements in them are just not cheap. Now, that WHERE condition will eventually get folded to the form s2 = ANY ('{1,2,...}'::integer[]) and that constant array is a *lot* less space-wasteful, only 4 bytes per element (or 8 bytes if we're talking bigints). So the approach I'd advise is trying to send the query with a constant array to begin with --- either write it like that, or like s2 = ANY ($1::integer[]) and send the array as an out-of-line parameter. Don't know how hard it might be to arm-wrestle ActiveRecord into doing it like that :-( regards, tom lane -- Sent via pgsql-general mailing list (pgsql-general@xxxxxxxxxxxxxx) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-general