Удалить акценты на строковом поле в запросе MySQL - PullRequest
0 голосов
/ 19 сентября 2018

У меня есть следующий запрос:

SELECT * FROM main_creditperson WHERE name="Irene Olga López"

Это будет повторяться:

id         name
366354     Irene Olga López

Есть ли простой способ сделать это в запросе , поэтомурезультат убран из всех акцентов?

id         name
366354     Irene Olga Lopez

Ответы [ 2 ]

0 голосов
/ 24 сентября 2018

Если COLLATION - это любой из вариантов ..._ci, то при сравнении акценты игнорируются.То есть код для удаления акцента не требуется.

0 голосов
/ 19 сентября 2018

Вы можете попытаться создать функцию для замены акцентов на обычное слово.

Схема (MySQL v5.6)

CREATE TABLE main_creditperson(id int,name Nvarchar(50));

INSERT INTO main_creditperson VALUES (366354,N'Irene Olga López');


ALTER TABLE main_creditperson 
MODIFY name VARCHAR(50) CHARACTER SET utf8mb4      
      COLLATE utf8mb4_bin; 

DROP FUNCTION IF EXISTS fn_remove_accents;
DELIMITER |
CREATE FUNCTION fn_remove_accents( textvalue VARCHAR(10000) ) RETURNS VARCHAR(10000)

BEGIN

    SET @textvalue = textvalue;

    -- ACCENTS
    SET @withaccents = 'ŠšŽžÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÑÒÓÔÕÖØÙÚÛÜÝŸÞàáâãäåæçèéêëìíîïñòóôõöøùúûüýÿþƒ';
    SET @withoutaccents = 'SsZzAAAAAAACEEEEIIIINOOOOOOUUUUYYBaaaaaaaceeeeiiiinoooooouuuuyybf';
    SET @count = LENGTH(@withaccents);

    WHILE @count > 0 DO
        SET @textvalue = REPLACE(@textvalue, SUBSTRING(@withaccents, @count, 1), SUBSTRING(@withoutaccents, @count, 1));
        SET @count = @count - 1;
    END WHILE;

    SET @special = '!@#$%¨&*()_+=§¹²³£¢¬"`´{[^~}]<,>.:;?/°ºª+*|\\''';
    SET @count = LENGTH(@special);

    WHILE @count > 0 do
        SET @textvalue = REPLACE(@textvalue, SUBSTRING(@special, @count, 1), '');
        SET @count = @count - 1;
    END WHILE;

    RETURN @textvalue;

END
|
DELIMITER ;

Запрос № 1

SELECT id,fn_remove_accents(name)  name
FROM main_creditperson 
WHERE name="Irene Olga López";

| id     | name             |
| ------ | ---------------- |
| 366354 | Irene Olga Lopez |

Просмотр базы данных Fiddle


Функция Ссылка

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...