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

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

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

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

WordPress

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

383閲覧

[WordPress] サイト内検索で一覧に出てくる記事の出方を変えたい

spellbound

総合スコア190

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

WordPress

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2017/11/17 04:37

編集2017/11/17 08:00

検索時のクエリ

SELECT SQL_CALC_FOUND_ROWS wp_posts.ID FROM wp_posts WHERE 1=1 AND ( wp_posts.ID NOT IN ( SELECT object_id FROM wp_term_relationships WHERE term_taxonomy_id IN (233,234,1578,9875,9876,16573,16574) ) ) AND (((wp_posts.post_title LIKE '%ペット%') OR (wp_posts.post_excerpt LIKE '%ペット%') OR (wp_posts.post_content LIKE '%ペット%'))) AND wp_posts.post_type IN ('post', 'page', 'attachment') AND (wp_posts.post_status = 'publish' OR wp_posts.post_author = 25 AND wp_posts.post_status = 'private') GROUP BY wp_posts.ID ORDER BY wp_posts.post_title LIKE '%ペット%' DESC, wp_posts.post_date DESC LIMIT 0, 20

%ペット% => 'ペット' に変更したいです。

環境

  • WordPress : 4.8.3
  • PHP : 5.6.20
  • Theme : Travelify

やりたいこと

  • 検索結果で表示される記事一覧を変えたい
  • つまり、検索した結果、取得される記事一覧の情報を変えたい
  • 例えば、現状だと、「ペット」で検索すると、「っと」や「ペッ」で始まる単語を含んでいる記事も、必要ないのに取得され、記事一覧に表示される
  • 検索クエリーを修正したいが、Travelifyの構造が分かりにくいため、分からなかった。
  • 検索クエリーを修正する方法を教えて欲しいです。
# search.php <?php /** * Displays the search results of the theme. * */ ?> <?php get_header(); ?> <?php /** * travelify_before_main_container hook */ do_action( 'travelify_before_main_container' ); ?> <div id="container" class="clearfix"> <?php /** * travelify_main_container hook * * HOOKED_FUNCTION_NAME PRIORITY * * travelify_content 10 */ do_action( 'travelify_main_container' ); ?> </div><!-- #container --> <?php /** * travelify_after_main_container hook */ do_action( 'travelify_after_main_container' ); ?> <?php get_footer(); ?>
<?php /** * Displays the searchform of the theme. */ ?> <form action="<?php echo esc_url( home_url( '/' ) ); ?>" class="searchform clearfix" method="get" role="search"> <label class="assistive-text" for="s"><?php _e( 'Search', 'travelify' ); ?></label> <input type="text" placeholder="<?php esc_attr_e( '気になるキーワードを入力', 'travelify' ); ?>" class="s field" name="s"> <input type="submit" value="&#xe905;" /> </form>

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

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

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

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

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

guest

回答2

0

テーマはこれでしょうか?
https://ja.wordpress.org/themes/travelify/

例えば、現状だと、「ペット」で検索すると、「っと」や「ペッ」で始まる単語を含んでいる記事も、必要ないのに取得され、記事一覧に表示される

そのテーマのデフォルトの状態だとそうはならないようです。
他のテーマでもそうはならないようです。
テーマのカスタマイズした部分か、何らかのプラグインが原因だと思います。
一度試しに手を加えていないテーマで試してみてはいかがでしょうか。

投稿2017/11/17 07:00

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

spellbound

2017/11/17 07:07

> そのテーマのデフォルトの状態だとそうはならないようです。 これが知れただけでも有り難いです。 なるほど。テーマをカスタマイズした結果そうなったのか、プラグインが影響している模様ですね。 ありがとうございます! まだ解決していないので、解決したらこの質問は閉めます。
spellbound

2017/11/17 07:21

ちなみに、このテンプレートの検索結果をいじるにはどこのファイルのどこをいじれば良いか分かりますか?
spellbound

2017/11/17 07:44

parse_search_order この関数が基本的なSQLを作っていそうです。
退会済みユーザー

退会済みユーザー

2017/11/17 08:07

検索結果を出力するのはtravelify_theloop_for_search()という関数のようですが、検索結果を変にしてしまうカスタマイズした内容から問題を見つけて改善するのが最善だと思いますが。
spellbound

2017/11/17 08:08

ありがとうございます!
guest

0

自己解決

照合順序を変える必要があるそうです。

utf8mb4_unicode_ciからutf8mb4_general_ciに変更すると直りそうです。

参考URL : https://www.slideshare.net/tmtm/mysql-62004569

投稿2017/11/21 07:15

spellbound

総合スコア190

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問