"select ... where field like lower('%text%')" fails

From: pgsql-bugs(at)postgresql(dot)org
To: pgsql-bugs(at)postgresql(dot)org
Subject: "select ... where field like lower('%text%')" fails
Date: 2001-03-06 11:34:00
Message-ID: 200103061134.f26BY0Y52994@hub.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

Sean Kelly (lists(at)shortestpath(dot)org) reports a bug with a severity of 1
The lower the number the more severe it is.

Short Description
"select ... where field like lower('%text%')" fails

Long Description
I am trying to search a varchar(x) field with a query like "select ... where field like lower('%someText%')".

In one field, if the value someText is at the very start then the search fails. In another field, if the value someText is at the very start then the search succeeds.

[See code - note results where 0 rows are returned]

Sample Code
isp=> \d user_tbl
Table "user_tbl"
Attribute | Type | Modifier
-----------+-------------+-------------------------
username | varchar(10) | not null
company | varchar(80) | not null
email | varchar(80) |
password | varchar(20) | not null
active | boolean | not null default 'TRUE'
created | timestamp | not null
Index: user_tbl_pkey

isp=> SELECT username,company,active,created from user_tbl where username = 'sean';
username | company | active | created
----------+---------------------+--------+------------------------
sean | Sean's Test Company | t | 2001-01-14 14:01:58+00
(1 row)

isp=> SELECT username,company,active,created from user_tbl where username like lower('%SEaN%');
username | company | active | created
----------+---------------------+--------+------------------------
sean | Sean's Test Company | t | 2001-01-14 14:01:58+00
(1 row)

isp=> SELECT username,company,active,created from user_tbl where company like lower('%SEaN%');
username | company | active | created
----------+---------+--------+---------
(0 rows)

isp=> SELECT username,company,active,created from user_tbl where company like lower('SEaN%');
username | company | active | created
----------+---------+--------+---------
(0 rows)

isp=> SELECT username,company,active,created from user_tbl where company like lower('%EaN%');
username | company | active | created
----------+---------------------+--------+------------------------
sean | Sean's Test Company | t | 2001-01-14 14:01:58+00
(1 row)

No file was uploaded with this report

Browse pgsql-bugs by date

  From Date Subject
Next Message pgsql-bugs 2001-03-06 11:34:03 "select ... where field like lower('%text%')" fails
Previous Message Nicolas GIMMILLARO 2001-03-06 11:22:43 seq scan on a table whereas an index exist