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

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

新規登録して質問してみよう
ただいま回答率
85.48%
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回答

352閲覧

投稿オブジェクトのタイトルを結合させたい

y.yamauchi

総合スコア5

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クリップ

投稿2019/11/01 14:16

前提・実現したいこと

Wordpressでの検索。

検索対象に、
・タイトルおよび記事本文 (こちらは正常に検索できています)
・カスタムフィールドで指定している「投稿オブジェクト」のタイトル
を含ませたい。

postsとpostmetaの中身は把握しています。
複雑化を避けるため、投稿オブジェクトは複数指定を禁止しています。

発生している問題・エラーメッセージ

カスタムフィールドに含まれている「投稿オブジェクト」のID取得までは成功しました。 ここで取得したIDでさらにpostsからタイトルを結合させようとしていますが、array()の空配列?で返ってきてしまいます。 出力結果はprint_rで確認しています。 もちろん、ループでも検索結果が出てきません。

該当のソースコード

PHP

1 2global $wpdb; 3$result = $wpdb->get_results(" 4 SELECT DISTINCT *, T2.meta_value AS 'brand_id' 5 FROM $wpdb->posts AS T1 6 JOIN $wpdb->postmeta AS T2 7 ON T1.ID = T2.post_id 8 JOIN $wpdb->posts AS T3 // ※ 9 ON T2.post_id = T3.ID // ※ 10 WHERE post_status = 'publish' 11 AND T2.meta_key = 'brand' 12");

試したこと

INNER, OUTER, LEFTを追加しても結果は変わりませんでした。
「※」部分の行を削ると正常に動作しますが、タイトルの文字列を取得できていないため、目的が果たされていません。

補足情報(FW/ツールのバージョンなど)

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

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

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

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

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

guest

回答2

0

ベストアンサー

もしかして

sql

1ON T2.post_id = T3.ID 2WHERE post_status = 'publish' 3AND T2.meta_key = 'brand' 45ON T2.meta_value = T3.ID 6AND T2.meta_key = 'brand' 7WHERE T1.post_status = 'publish'

なのでは?

sql

1T3.post_title AS 'brand_name'

みたいな記述もいるかな?

投稿2019/11/01 16:24

編集2019/11/01 16:44
KazuhiroHatano

総合スコア7804

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

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

y.yamauchi

2019/11/01 16:32

ご回答ありがとうございます。 試した事のない文だったので、早速試してみましたが、結果は「Array()」でした。
y.yamauchi

2019/11/01 17:07

ANDの場所を入れ替える発想が無かったので、色々試してみていますが、まだ成功していません。 以下、※部分を削除した場合の出力結果です。 (読みやすくするために整形しています) ```出力結果 $result = array( [0] => array( [ID] => 13, [post_author] => 0, [post_date] => '2019-04-24 01:31:28', [post_date_gmt] => '2019-04-23 16:31:28', [post_content] => '本文', [post_title] => 'タイトル', [post_excerpt] => '', [post_status] => 'publish', [comment_status] => 'closed', [ping_status] => 'closed', [post_password] => '', [post_name] => '投稿名', [to_ping] => '', [pinged] => '', [post_modified] => '2019-10-27 18:19:02', [post_modified_gmt] => '2019-10-27 09:19:02', [post_content_filtered] => '', [post_parent] => 0, [guid] => 'URL, [menu_order] => 0, [post_type] => 'product' , [post_mime_type] => '', [comment_count] => 0, // ここから下がJOINされたデータです。 [meta_id] => 30, [post_id] => 13, [meta_key] => 'brand', [meta_value] => 21, // SELECTで追加された内容です [brand_id] => 21 ), ... ); ``` postmetaにpostsが結合できない事を疑って入れ替えてみましたが、その場合は上記の配列順が変わるだけで、正常に出力されました。
guest

0

WHEREの「post_status = ‘publish’」を消したら無事表示されました。
原因よくわかっていませんが、postmetaテーブルがpost_statusプロパティを持ってなかったからなんじゃないかと思っています。
ANDの位置を動かす事がヒントになりました。ありがとうございます。

以下、正常に出力されたコード(SQL文?)です。

PHP

1 2$result = $wpdb->get_results(" 3 SELECT DISTINCT *, T2.meta_value AS 'brand_id', T3.post_title AS 'brand_name' 4 FROM $wpdb->posts AS T1 5 JOIN $wpdb->postmeta AS T2 6 ON T1.ID = T2.post_id 7 LEFT JOIN $wpdb->posts AS T3 8 ON T2.meta_value = T3.ID 9 WHERE T2.meta_key = 'brand' 10 AND T2.meta_key = 'brand' 11"); 12

データベースの中身を分解していくうちに、解った事があるので追記します。

投稿オブジェクトを複数指定にした場合は、
Advanced Custom Fields専用のユニーク値で格納されるため、
SQLではどうやっても取り出せないようです。

(配列がそのままテキストなどで保存されると期待していましたが、そうではありませんでした。)

投稿2019/11/01 17:51

編集2019/11/09 16:20
y.yamauchi

総合スコア5

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問