有没有办法在PostgreSQL中编写不区分大小写的查询,例如,我想下面3个查询返回相同的结果。
SELECT id FROM groups where name='administrator'
SELECT id FROM groups where name='ADMINISTRATOR'
SELECT id FROM groups where name='Administrator'
有没有办法在PostgreSQL中编写不区分大小写的查询,例如,我想下面3个查询返回相同的结果。
SELECT id FROM groups where name='administrator'
SELECT id FROM groups where name='ADMINISTRATOR'
SELECT id FROM groups where name='Administrator'
当前回答
如果你不仅想要大写/小写,还想要变音符,你可以实现你自己的func:
CREATE EXTENSION unaccent;
CREATE OR REPLACE FUNCTION lower_unaccent(input text)
RETURNS text
LANGUAGE plpgsql
AS $function$
BEGIN
return lower(unaccent(input));
END;
$function$;
调用是then
select lower_unaccent('Hôtel')
>> 'hotel'
其他回答
限制使用ILIKE
select id from groups where name ILIKE 'adminstration';
如果你来,expressjs的背景和名称是一个变量 使用
select id from groups where name ILIKE $1;
你可以用ILIKE。即。
SELECT id FROM groups where name ILIKE 'administrator'
使用~*可以通过INSTR的功能极大地提高性能。
SELECT id FROM groups WHERE name ~* 'adm'
返回name包含OR = 'adm'的行。
您还可以阅读ILIKE关键字。尽管它不符合SQL标准,但有时它非常有用。更多信息请访问:http://www.postgresql.org/docs/9.2/static/functions-matching.html
一种经过测试的方法是使用~*
如下面的例子所示
SELECT id FROM groups WHERE name ~* 'administrator'