3

何時間も質問を検索しましたが、自分に合った答えが見つからなかったので...ここに来ました...

私はハンガリー語で、私たちの言語では次のアクセント記号付きの文字を使用しています。 MySQlテーブルまたは検索フィールドの両方にアクセントがあるかどうか。それで...

私のMySQLテーブルはutf8_hungarian_ciを使用しています。ユーザーが「Bla」または「blá」と入力すると「bla」が返され、mySQLデータベースを検索するようにphp変換を実行できます。

しかし、私の問題は...私のデータベースには「blafér」または「bláter」フィールドエントリがある可能性があります。しかし、(PHPから)「bla」で検索すると、「blafer」のみが返されます。検索しているフィールドを変換して、「blafér」->「blafer」および「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 áéíóöőúüű
?>
4

2 に答える 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

于 2012-04-05T07:34:29.343 に答える