PostgreSQL: função TO_ASCII em banco UTF-8

A função TO_ASCII no postgresql é muito útil principalmente para buscas onde se quer ignorar acentos em string. Ela funciona bem quando o banco de dados estiver em LATIN1 por exemplo.

SELECT TO_ASCII('tchê'); -- retorna 'tche'

mas quando usamos ela em um banco UTF8 retorna o erro “conversão de condificação de UTF8 para ASCII não é suportada”.

Para contornar esse problema, cria-se, uma função de banco onde podemos chamar de SEM_ACENTO, para usar no lugar da TO_ASCII.

CREATE OR REPLACE FUNCTION SEM_ACENTO(text)
RETURNS text AS
$BODY$
select
translate($1,'áàâãäéèêëíìïóòôõöúùûüÁÀÂÃÄÉÈÊËÍÌÏÓÒÔÕÖÚÙÛÜçÇ',
        'aaaaaeeeeiiiooooouuuuAAAAAEEEEIIIOOOOOUUUUcC');
$BODY$
LANGUAGE 'sql' IMMUTABLE STRICT;

2 Respostas to “PostgreSQL: função TO_ASCII em banco UTF-8”

  1. PostgreSQL: migrando de LATIN1 pra UTF-8 « Fábio Arezi Says:

    […] use em seus SQL a função TO_ASCII, com UTF-8 ela não irã funcionar. Veja aqui a alternativa em um post passado que eu […]

  2. PostgreSQL: migrando de LATIN1 pra UTF-8 « Fábio Arezi Says:

    […] use em seus SQL a função TO_ASCII, com UTF-8 ela não irã funcionar. Veja aqui a alternativa em um post passado que eu fiz. Publicado em Desenvolvimento, Linux, PostgreSQL. Tags: converter, […]


Deixe um comentário