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

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

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

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

Q&A

解決済

1回答

1352閲覧

WP 複数のmeta_queryにマッチすると、二重にカウントされてしまう

cwhiro

総合スコア21

WordPress

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

0グッド

0クリップ

投稿2020/10/13 05:27

編集2020/10/13 06:53

こんにちは

基本的な内容で恐縮です。
meta_queryなのですが、下記のようにセットしたところ、例えば1つの記事で、二つの条件ともにマッチした場合に、記事数が二重にカウントされています。
どちらの条件にもマッチする場合には、メタキー1bbの条件のみカウントさせるということはできるものでしょうか。

<?php $args = array( 'category_name' => $cat, 'posts_per_page' => -1, 'post_type' => 'post', 'post_status' => 'publish', 'meta_query' => array( 'relation' => 'or', array( 'key'=> '1bb', 'value' => array($from , $to), 'compare' => 'BETWEEN', 'type' => 'DATE', ), array( 'key'=> '1aa', 'value' => array($from , $to), 'compare' => 'BETWEEN', 'type' => 'DATE', ), ), ); echo count( get_posts( $args ) ); ?>

追記です

1aaだけマッチするときの条件、1bbだけマッチするときの条件、1aaも1bbも両方マッチするときの条件、といった3つのmeta_queryを仮にセットしてみましたが、表示ができないほど読み込みに時間がかかってしまい、ダメでした。

'meta_query' => array( 'relation' => 'or', array( 'relation' => 'AND', array( array( 'key'=> '1aa', 'value' => array($from , $to), 'compare' => 'BETWEEN', 'inclusive' => 'true', 'type' => 'DATE', ), array( 'key' => '1bb', 'compare' => 'NOT EXISTS', ), ), ), array( 'relation' => 'AND', array( array( 'key'=> '1bb', 'value' => array($from , $to), 'compare' => 'BETWEEN', 'inclusive' => 'true', 'type' => 'DATE', ), array( 'key' => '1aa', 'compare' => 'NOT EXISTS', ), ), ), array( 'relation' => 'AND', array( array( 'key'=> '1bb', 'value' => array($from , $to), 'compare' => 'BETWEEN', 'inclusive' => 'true', 'type' => 'DATE', ), array( 'key' => '1aa', 'compare' => 'EXISTS', ), array( 'key' => '1bb', 'compare' => 'EXISTS', ), ), ), ),

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

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

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

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

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

tabuu

2020/10/13 06:22

「記事数が二重にカウントされています。」とはどこで確認されていますか?
tabuu

2020/10/13 06:22

失礼しました。最後に書いていますね。
cwhiro

2020/10/13 06:53

目を通していただいてありがとうございます。
KazuhiroHatano

2020/10/13 11:00

wp_query->get_postsはGROUP BY {$wpdb->posts}.ID して post_idを重複なく取得した後にそのIDからpostデータを取得するという処理をしています 通常重複するはずがありません 一度get_postsで取得された内容を精査してください
cwhiro

2020/10/14 07:53

ありがとうございます。いただいたコメントを元に解決することができました。メタキーの 1aaと1bbが、それぞれ違う月をバリューとするとき、3か月分を1か月ごとに記事数をとると、複数の月でカウントされますが、まとめて記事数をとると、1カウント分のみでした。月ごとに個別にカウントしたせいで重複していました。
guest

回答1

0

自己解決

メタキーの 1aaと1bbが、それぞれ違う月をバリューとするとき、3か月分を1か月ごとに記事数をとると、複数の月でカウントされますが、まとめて記事数をとると、1カウント分のみでした。月ごとに個別にカウントしたせいで重複していました。

投稿2020/10/14 07:55

cwhiro

総合スコア21

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問