重音字符和MySQL搜索

3
我搜索了几个小时也没找到适合我的答案,所以我来这里请教。我来自匈牙利,我们的语言中使用以下重音字符: áéíóöőúüű(当然还有大写字母)。我想在PHP中实现智能搜索,使用户可以输入一个搜索词,并在MySQL表或搜索字段中查找结果,无论是否有重音。因此……
我的MySQL表使用utf8_hungarian_ci。我可以进行PHP转换,使得无论用户键入'bla'或'blá'都会返回'bla',并且在MySQL数据库中进行搜索。
但是我的问题是……我的数据库可能会有'bla fér'或'bláter'字段条目。但如果我们使用从PHP搜索的'bla',它只返回'bla fer'。如何转换我正在搜索的字段,使'bla fér' -> 'bla fer'和'bláter' -> 'blater'。因此,实质上……
我想去掉重音符号,并将其转换为没有重音符号的字符。但是当然,仅仅是为了搜索。请帮帮我!谢谢!
编辑:
<?php 
$search = $_GET["search"]; // May contain áéíóöőúüű
$accented= array("Ö","ö","Ü","ü","ű","Ó","ó","O","o","Ú","ú","Á","á","U","u","É","é","Í","í"," ","+","'","ő", "Ű", "Ő", "ä","Ä","ű","Ű","ő","Ő");
$nonaccented=array("O","o","U","u","u","O","o","O","o","U","u","A","a","U","u","E","e","I","i","_","_","_","o", "U", "O", "a","A","u","u","o","o");
$search = str_replace($accented,$nonaccented,$search);
$query = "SELECT id, name FROM people WHERE name LIKE '%$search%'"; // Database column 'name' may also contain áéíóöőúüű
?>

你能发布相关的SQL和php代码吗? - barsju
可能是重复问题:https://dev59.com/aHA75IYBdhLWcg3wboYz - barsju
我尝试了https://dev59.com/aHA75IYBdhLWcg3wboYz,但对我没有用。我将字符设为了utf8。 - user1177476
你遇到了同样的问题吗?你找到原因了吗? - MastaBaba
2个回答

1
这是我测试的一些结果。你可以与你的进行比较:
CREATE TABLE `test` (
  `id` int(11) NOT NULL auto_increment,
  `name` varchar(32) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8

目录:

mysql> select * from test;
+----+---------+
| id | name    |
+----+---------+
|  1 | bla     | 
|  2 | blater  | 
|  3 | bláter | 
|  4 | bhei    | 
+----+---------+
4 rows in set (0.00 sec)

搜索结果;

mysql> select * from test where name like '%bla%';
+----+---------+
| id | name    |
+----+---------+
|  1 | bla     | 
|  2 | blater  | 
|  3 | bláter | 
+----+---------+
3 rows in set (0.00 sec)

带口音的搜索:

mysql> select * from test where name like '%blá%';;
+----+---------+
| id | name    |
+----+---------+
|  3 | bláter | 
+----+---------+
1 row in set (0.00 sec)

即使使用 COLLATE=utf8_hungarian_ci,我仍然得到相同的结果。


我不知道。也不知道为什么……可能是因为旧的MySQL版本吗? - user1177476
我正在运行5.0.77版本。你是重现了我的测试还是使用了自己的表格? - barsju

0

对我来说,将字符编码设置为utf8_general_ci(或其他带有“_ci”的内容)就可以解决问题了。_ci表示SQL将匹配不考虑大小写或重音符号的搜索。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接