質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Q&A

解決済

1回答

5632閲覧

ワードプレスサイト内検索「濁点、半濁点を分離」させたい

glanglan

総合スコア36

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

0グッド

0クリップ

投稿2017/03/26 23:57

###前提・実現したいこと
ワードプレスの検索フォームに、濁点・半濁点を区別させて検索結果表示させたい

###現在の状況

現在、トップページに <?php get_search_form(); ?> で検索フォームを表示させています。 が、これだと1つ弊害が。濁点、半濁点が区別されないのです。 ●「すし」で検索すると「スジ」もヒット ●「パン」で検索すると「ハンガー」もヒット など。 濁点がつくと、違う意味になるにもかかわらず 同一文字として認識されるので少々厄介です。 濁点、半濁点を分離させる記述方法があれば教えてください

###該当のソースコード

メインインデックスphp内に <?php get_search_form(); ?> を記述

###補足情報(言語/FW/ツール等のバージョンなど)
バージョン 4.7.3

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

MySQL は、utf8_general_ci のテーブルでは「大文字・小文字、清音・濁音・半濁音」を区別しない仕様だったと思います。utf8_bin であれば、区別します。

解決方法としては、テーブルを utf8_bin で作り直すか SQL 実行時に、BINARY をつけて比較することになると思います。

WordPress の SQL を調べてみたところ、LIKE で検索していますので、この LIKE を LIKE BINARY に変更すると「大文字・小文字、清音・濁音・半濁音」を区別して検索できると思います。

動作確認として、上記の LIKE から LIKE BINARY への変更を WordPress のソースで、SQLを探して直接書き換えると、検索結果が変わることを確認しました。
他の弊害もあるかもしれないのとソースを直接書き換えるのは推奨されていないので、できればフックを使って、SQLを書き換えるべきなのですが、どのフックがいいのか見つけれていません。

投稿2017/03/27 00:59

編集2017/03/27 01:11
CHERRY

総合スコア25216

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

CHERRY

2017/03/27 01:17

思いついた問題点として、例えば「Apple」で、検索した場合、オリジナルのままなら Apple, APPLE, apple, Pineapple 等が検索されると思いますが、BINARY 検索すると 完全一致する Apple しか検索できなくなります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問