Anton Melser <melser.anton@xxxxxxxxx> writes: > I moved a DB between two "somewhat" similar Postgres installs and am > getting much worse plans on the second. The DB was dumped via pg_dump > (keeping indexes, etc.) and loaded to the new server. > [ "like 'foo%'" is not getting converted into index bounds ] I'd bet your old database is in C locale and the new one is not. The LIKE optimization requires an index that's sorted according to plain C (strcmp) rules. A regular text index will be that way only if the database's LC_COLLATE is C. If you don't want to rebuild the whole database, you can create indexes to support this by declaring them with COLLATE "C", or the older way is to declare them with text_pattern_ops as the index opclass. regards, tom lane -- Sent via pgsql-performance mailing list (pgsql-performance@xxxxxxxxxxxxxx) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-performance