Lower Is Faster Than ilike
There are a couple ways to do a case-insensitive comparison of data in PostgreSQL. One way is to use the ilike operator for comparison. Another way is to use the lower() function on both sides of the = operator for comparison. Using lower() is a bit faster than using ilike.
When comparing
select * from users where email ilike 'some-email@example.com';to
select * from users where lower(email) = lower('some-email@example.com');we find (via explain analyze) that using lower() was taking around 12ms where as the ilike example was taking around 17ms.
We earn orders of magnitude in performance when adding a functional index that uses the lower() function like so:
create unique index users_unique_lower_email_idx on users (lower(email));After adding this index, the example using lower() drops to around 0.08ms.
For the full example and explain analyze outputs, see this document.
Last updated
Was this helpful?