有没有办法在PostgreSQL中编写不区分大小写的查询,例如,我想下面3个查询返回相同的结果。

SELECT id FROM groups where name='administrator'

SELECT id FROM groups where name='ADMINISTRATOR'

SELECT id FROM groups where name='Administrator'

当前回答

你可以用ILIKE。即。

SELECT id FROM groups where name ILIKE 'administrator'

其他回答

在比较之前,使用LOWER函数将字符串转换为小写。

试试这个:

SELECT id 
  FROM groups
 WHERE LOWER(name)=LOWER('Administrator')

限制使用ILIKE

select id from groups where name ILIKE 'adminstration';

如果你来,expressjs的背景和名称是一个变量 使用

select id from groups where name ILIKE $1;
-- Install 'Case Ignore Test Extension'
create extension citext;

-- Make a request
select 'Thomas'::citext in ('thomas', 'tiago');

select name from users where name::citext in ('thomas', 'tiago');
select id from groups where name in ('administrator', 'ADMINISTRATOR', 'Administrator')

一种经过测试的方法是使用~*

如下面的例子所示

SELECT id FROM groups WHERE name ~* 'administrator'