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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

Q&A

解決済

2回答

2009閲覧

PHPでMySQL接続処理を共通化させたい

kofaproki.0627

総合スコア4

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

0グッド

0クリップ

投稿2022/04/07 11:13

PHPでMySQL接続処理を共通化させたいと思い、
『初心者からちゃんとしたプロにになるPHP基礎入門』を参考に作成しました。

・データベースの名前はdbname(本来は違う名前を設定しています)
・パスワードはpassword(本来は違う名前を設定しています)
・localhostで接続
・rootで接続
とします。

まず、共通化する部分はfunction.phpとし

PHP

1 2function str2html(string $string) :string{ 3 return htmlspecialchars($string, ENT_QUOTES, 'UTF-8'); 4} 5 6function db_open() :PDO{ 7 $user = "root"; 8 $password = "pssword"; 9 $opt = [ 10 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTOPN, 11 PDO::ATTR_EMULATE_PREPARES => false, 12 PDO::MYSQL_ATTR_MULTI_STATEMENTS => false, 13 ]; 14 $dbh = new PDO('mysql:host=localhost;dbname=dbname', $user, $password, $opt); 15 return $dbh; 16} 17var_dump($dbh);

本来はvar_dumpすると、

function.php

1object(PDO)#1 (0) {}

と接続できたことがわかるはずですが、今は

function.php

1Warning: Undefined variable $dbh in C:\xampp\htdocs\function.php on line 36 2NULL

となってしまいます。
本通りに記述しているのですが、何が間違っているのでしょうか?
共通化する前に記述していた、

PHP

1$dsn = 'mysql:dbname=dbname;host=localhost;charset=utf8'; 2$user = 'root'; 3$password = 'password'; 4 5try{ 6 7 $dbh = new PDO($dsn, $user, $password,[ 8 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, 9 ]); 10 echo '接続成功'; 11} catch(PDOException $e){ 12 echo '接続失敗'. $e-> getMessage(); 13 exit(); 14};

ではきちんと接続できていたので、パスワード等の間違いはありません。

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

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

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

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

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

guest

回答2

0

Warning: Undefined variable $dbh in C:\xampp\htdocs\function.php on line 36

↑の警告は$dbhという変数が定義されていないという意味です。
$dbhdb_open()で宣言されており、関数の外はスコープ外なので存在しない変数(=NULL)として扱われます。

db_open()はDBコネクションを返すようになっているので、↓のように関数の戻り値を変数に代入すれば期待通りの結果が得られると思います。

$dbh = db_open(); var_dump($dbh);

投稿2022/04/07 11:29

madoka-t

総合スコア379

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

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

kofaproki.0627

2022/04/07 11:48

ありがとうございます! 本には「ここでvar_dump($dbh)すればobject(PDO)#1 (0) {}と出ます」としか書いていませんでした。 しかし、共通化し、各ページにrequire_once 'function.php'を記述した後、 必ず「$dbh = db_open();」と書いてありました。 ここがポイントだったんですね、ありがとうございました!
guest

0

ベストアンサー

typo

PHP

1PDO::ERRMODE_EXCEPTOPN 2↓↓↓ 3PDO::ERRMODE_EXCEPTION

それと$dbhを参照できない

PHP

1$dbh=db_open(); 2var_dump($dbh); 3```

投稿2022/04/07 11:24

編集2022/04/07 11:26
yambejp

総合スコア114812

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

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

kofaproki.0627

2022/04/07 11:49

タイプミス気づきませんでした! 本当にありがとうございます。 スッキリしました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問