在mysql查询中删除字符串字段上的重音符号

sigwle7e  于 2021-06-19  发布在  Mysql
关注(0)|答案(2)|浏览(515)

我有以下疑问:

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

这将导致:

  1. id name
  2. 366354 Irene Olga López

有没有一种简单的方法可以在查询中这样做,从而删除所有重音符号的结果?

  1. id name
  2. 366354 Irene Olga Lopez
sgtfey8w

sgtfey8w1#

您可以尝试创建一个函数来替换普通单词的重音符号。
架构(mysql v5.6)

  1. CREATE TABLE main_creditperson(id int,name Nvarchar(50));
  2. INSERT INTO main_creditperson VALUES (366354,N'Irene Olga López');
  3. ALTER TABLE main_creditperson
  4. MODIFY name VARCHAR(50) CHARACTER SET utf8mb4
  5. COLLATE utf8mb4_bin;
  6. DROP FUNCTION IF EXISTS fn_remove_accents;
  7. DELIMITER |
  8. CREATE FUNCTION fn_remove_accents( textvalue VARCHAR(10000) ) RETURNS VARCHAR(10000)
  9. BEGIN
  10. SET @textvalue = textvalue;
  11. -- ACCENTS
  12. SET @withaccents = 'ŠšŽžÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÑÒÓÔÕÖØÙÚÛÜÝŸÞàáâãäåæçèéêëìíîïñòóôõöøùúûüýÿþƒ';
  13. SET @withoutaccents = 'SsZzAAAAAAACEEEEIIIINOOOOOOUUUUYYBaaaaaaaceeeeiiiinoooooouuuuyybf';
  14. SET @count = LENGTH(@withaccents);
  15. WHILE @count > 0 DO
  16. SET @textvalue = REPLACE(@textvalue, SUBSTRING(@withaccents, @count, 1), SUBSTRING(@withoutaccents, @count, 1));
  17. SET @count = @count - 1;
  18. END WHILE;
  19. SET @special = '!@#$%¨&*()_+=§¹²³£¢¬"`´{[^~}]<,>.:;?/°ºª+*|\\''';
  20. SET @count = LENGTH(@special);
  21. WHILE @count > 0 do
  22. SET @textvalue = REPLACE(@textvalue, SUBSTRING(@special, @count, 1), '');
  23. SET @count = @count - 1;
  24. END WHILE;
  25. RETURN @textvalue;
  26. END
  27. |
  28. DELIMITER ;

查询#1

  1. SELECT id,fn_remove_accents(name) name
  2. FROM main_creditperson
  3. WHERE name="Irene Olga López";
  4. | id | name |
  5. | ------ | ---------------- |
  6. | 366354 | Irene Olga Lopez |

db fiddle视图
函数引用

展开查看全部
sshcrbum

sshcrbum2#

如果 COLLATION 有什么问题吗 ..._ci 变体,则在比较时忽略重音符号。也就是说,不需要重音消除代码。

相关问题