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

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

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

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

PHP

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Q&A

解決済

3回答

299閲覧

データベースをチェックするコードの関数化がうまくできません

yayak

総合スコア66

WordPress

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

PHP

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

0グッド

0クリップ

投稿2018/08/20 11:42

編集2018/08/20 11:44

データベースをチェックするコードを関数化しようとしているのですが、うまくいきません。

関数化しないときは、うまく動作します。

関数化する前の文(想定通りの動作をします)

try { global $wpdb; $users_table = $wpdb->prefix . "users"; //ユーザーテーブルを定義 $session_ID = $_SESSION["ID"]; //セッションIDを定義 $check_DB_users_table = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM $users_table WHERE ID = %d", "$session_ID" ), ARRAY_A ); } catch( PDOException $e ) { // PDOException の場合のみ wp_die('データベースエラーが発生しました。'); } catch( Exception $e ) { // PDOException でキャッチできなかった例外はこっち wp_die('何らかのエラーが発生しました。'); } echo $check_DB_users_table['user_email'] //ユーザーテーブルの指定されたIDに登録されたメールアドレスが出力されます。

上の文を関数化した結果、うまくいかない例

function check_DB_users_table_by_id() { try { global $wpdb; $users_table = $wpdb->prefix . "users"; //ユーザーテーブルを定義 $session_ID = $_SESSION["ID"]; //セッションIDを定義 $check_DB_users_table = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM $users_table WHERE ID = %d", "$session_ID" ), ARRAY_A ); } catch( PDOException $e ) { // PDOException の場合のみ wp_die('データベースエラーが発生しました。やり直してください。'); } catch( Exception $e ) { // PDOException でキャッチできなかった例外はこっち wp_die('何らかのエラーが発生しました。やり直してください。'); } } //関数を実行 check_DB_users_table_by_id(): echo $check_DB_users_table['user_email'] //何も出力されない

関数化する前はうまくいくコードが、関数化したら動かなくなってしまう原因がわからず、頭がこんがらがっています。。

どなたか、原因がわかる方がいらっしゃいましたら、道しるべを頂けましたら幸いです。

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

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

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

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

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

kei344

2018/08/20 12:57

まだ質問が「受付中」になっていますが、「ベストアンサー」を選び「解決済」にされてはいかがでしょうか。
yayak

2018/08/20 12:59

失礼いたしました!解決済みに変更します。
guest

回答3

0

ベストアンサー

function check_DB_users_table_by_id() { try { global $wpdb; $users_table = $wpdb->prefix . "users"; //ユーザーテーブルを定義 $session_ID = '1'; //セッションIDを定義 $check_DB_users_table = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM $users_table WHERE ID = %d", "$session_ID" ), ARRAY_A ); } catch( PDOException $e ) { // PDOException の場合のみ wp_die('データベースエラーが発生しました。やり直してください。'); } catch( Exception $e ) { // PDOException でキャッチできなかった例外はこっち wp_die('何らかのエラーが発生しました。やり直してください。'); } return $check_DB_users_table; }

echo check_DB_users_table_by_id()['user_email'];とか。

投稿2018/08/20 12:22

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

yayak

2018/08/20 12:36

上記のようにしないと動作しない理由なども、今回の皆様の回答のおかげで理解が深まりました。 本当に有難うございます。 もっともっと勉強します!
guest

0

WPはいまいちわからないのですが、普通に

check_DB_users_table_by_id()内でローカル変数$check_DB_users_tableに
値を設定しても、スコープ外から参照できないだけでは?

  • $check_DB_users_tableを引数で処理するとか
  • $check_DB_users_tableをグローバルにするとか
  • $check_DB_users_tableをreturnして外で受けるとか

PHP

1hoge($a); 2function hoge(&$b=null){ 3 $b=1; 4} 5print $a;

投稿2018/08/20 12:11

yambejp

総合スコア114843

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

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

yayak

2018/08/20 12:33

リターンして外で受け取りましたところ、想定していた動作になりました。 本当に有難うございます。 感謝感激です。
guest

0

関数の中の$check_DB_users_tableは関数が終了すると破棄されるのでそれが正しい動作です。

投稿2018/08/20 12:11

hichon

総合スコア5737

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

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

yayak

2018/08/20 12:32

その通りすぎて赤面してベッドでじたばたしております。 ご回答、心より感謝いたします。 有難うございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問