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

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

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

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

Q&A

解決済

1回答

2138閲覧

Wordpressで投稿数が0のタームだけを抽出したい。

muro

総合スコア99

WordPress

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

0グッド

0クリップ

投稿2018/09/13 07:29

編集2018/09/13 10:42

php

1$offset = 0; 2do { 3 $terms = get_terms("hogehoge", [ 4 "hide_empty" => 0, 5 "number" => 100, 6 "offset" => $offset, 7 ]); 8 foreach($terms as $term) { 9 if($term->count == 0) { 10 wp_delete_term($term->term_id, "hogehoge"); 11 } 12 } 13 $offset += 100; 14} while (!empty($terms));

投稿数が0件のタームのみをget_termsで抽出したいと考えています。
投稿0件のタームも含むという設定ならhide_emptyでできるのですが、0件だけという引数がわかりませんでした。
よって、いったんすべてのタームを取得してから、それぞれのカウントを調べて、0件だったらアクションを実行する、という流れに変えました。
しかし、タームも投稿数も何千件も存在するせいか、「Allowed memory size of 268435456 bytes exhausted (tried to allocate 466944 bytes) in /var/www/html/wp-includes/functions.php on line 3743」というエラーを起こしてしまいました。
一気にやるとメモリリークするのかと思って、100件ずつ処理するようにもしてみましたが、それでも同じエラーになってしまいます。

php

1$ids = get_terms("hogehoge", [ 2 "hide_empty" => 0, 3 "fields" => "ids", 4]); 5foreach($ids as $term_id) { 6 $term = get_term($term_id, "hogehoge"); 7 if($term->count === 0) { 8 wp_delete_term($term->term_id, "hogehoge"); 9 } 10}

次に、上記のようにタームのidだけの配列を取得して、その配列でforeachする方法に変えてみました。
すると、いくつかの投稿0件のタームは取得できたのですが、途中で相変わらずメモリリークが発生してしまいました。

わざわざすべてのタームを取得しなくても、投稿0件のタームだけ抜き出す方法はないでしょうか?

[追記]
本質問を作成当初、0件だったときの処理をvar_dumpとしていましたが、正しくはwp_delete_termです。
すべてのタームが入った配列をvar_dumpしてもメモリリークとはならず、wp_delete_termのときに発生していたと思われます。

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

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

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

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

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

guest

回答1

0

ベストアンサー

内部で WP_Term_Query を使用しているので、terms_clauses フィルタで where を書き換えれば出来そうです。(未検証)

【WP_Term_Query | Class | WordPress Developer Resources】
https://developer.wordpress.org/reference/classes/wp_term_query/

【データベース構造 - WordPress Codex 日本語版】
https://wpdocs.osdn.jp/データベース構造#.E3.83.86.E3.83.BC.E3.83.96.E3.83.AB:_wp_terms

【WordPressのget_terms()で、特定の投稿タイプのみcountの対象にする方法 - Daily GLOCALISM】
http://daily.glocalism.jp/wordpress/get-terms-for-specific-post-type-only/
※ 書き換えの例。直接同じ事をしているわけではないがこれをもとにできそう。

投稿2018/09/13 07:58

kei344

総合スコア69407

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

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

muro

2018/09/14 11:15

回答ありがとうございます。下記のコードで、投稿数が0件のタームのみ取得できました。 function test() { $terms = get_terms("hogehoge", [ "hide_empty" => false, "empty" => true, ]); var_dump($terms); } add_filter("terms_clauses", function ($clauses, $taxonomy, $args) { if($args["empty"] === true) { $clauses["where"] .= " AND tt.count = 0"; } return $clauses; }, 10, 3);
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問