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

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

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

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

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

Q&A

1回答

1055閲覧

PHP+MySQL の正しいデータベース接続箇所を知りたい

yy_hatena

総合スコア12

MySQL

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

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

0グッド

0クリップ

投稿2021/05/29 03:49

編集2021/05/29 03:57

PHP 初心者です。どうぞ宜しくお願いします。

<利用環境>
PHP 7
MySQL 5.6

##知りたいこと
php の PDO を利用したMySqlへの接続で、例えば、
「A」という名前のクラス内で、SQL文 が書かれた method_1() という関数を、
「B」という名前のクラス内で実行した場合、データベースへの接続は正常にされるのか?を知りたいです。
このとき、「A」という名前のクラスでは、データベースへの接続は行いません。


コードで書くと下記のようなイメージです。

PHP

1// php_1.php に記述 2class DB { 3 4 protected function DbConnect(){ 5 6 $this->user = 'user'; 7 $this->pw = 'pw'; 8 $this->dbname = 'dbname'; 9 $this->host = 'host'; 10 $this->db_type = 'db_type'; 11 $this->db_host = 'db_host'; 12 $this->connect = new PDO($this->db_host, $this->user, $this->pw); 13 $this->connect->query('SET NAMES utf8'); 14 15 } 16 17} 18 19 20// php_2.php に記述 21class A extends DB{ 22 23  public function method_1($var){ 24 25   // 色々なところで使うことを想定した関数です。ここでは、データベースには接続しない状態です。 26   /************************************************************************ 27   理由 28   この関数をループ内でも使用する場合があり、ここで接続をしてしまうと、 29   ループの回数分、接続を繰り返すことで重くなりそう、と思ってたりしますがどうなんでしょうか?そんなことはないでしょうか...? 30   ***********************************************************************/ 31   $this->getDate = $var ; // $var はエスケープされているものとします 32   $sql = 'SELECT * FROM `table_name` WHERE `date` = :date'; 33   $stmt = $this->connect->prepare($sql); 34   $stmt->bindParam(":date", $this->getDate, PDO::PARAM_INT); 35   $stmt->execute(); 36   $sql_error = $stmt->errorInfo(); 37   // 以降はSQLの実行結果を分岐して結果を return で返します。 38  } 39 40} 41 42 43 44// php_3.php に記述 45class B extends DB { 46 47   // データベース接続 48   $this->DbConnect(); 49    50   // class A 51   $this->Class_A = new A(); 52    53   // 日付などのループ処理 54   while(checkdate($m, $d, $y)){ 55     $date = $y.$m.$d; 56     /**************************************** 57     ここが、ちゃんと接続されるのか?を知りたいです。 58     ****************************************/ 59     $this->Class_A->method_1($date); 60     ++$d ; 61   } 62 63   // データベース切断 64   $this->connect = NULL ; 65 66} 67

このとき、method_1() という関数は、正常にデータベースに接続されるのか?を知りたいです。
※ 現状、接続できずにエラーが出ています。

また、上記のような場合に、もっと正しいデータベース接続箇所があれば、教えて頂きたいです。
※ フレームワーク等は使わずに、勉強のために知りたいです。

すみません、上記コードでは情報が足りないかもしれませんが、お分かりになる範囲で教えて頂けると幸いです。
どうぞ宜しくお願い申し上げます。

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

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

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

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

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

m.ts10806

2021/05/29 04:12

「イメージ」ではなく、実際のコードと出ているエラーを提示されたほうが良いかと思います。お互いイメージでは話が進みません。
yy_hatena

2021/05/29 04:18

ありがとうございます!ご指摘の通りです。申し訳ございません! 再度、コードを修正致します。
guest

回答1

0

クラスBでのデータベース接続をクラスAに反映させるのは無理があります。
未検証ですが、クラスAのコンストラクタにデータベース接続のインスタンスを用意するとよいと思います。
データベースのインスタンス名を$sql_dbとすれば、以下のようなコードです。

php

1 // class A 内におく最初のデータベース接続のコンストラクタ。 2 function __construct(){ 3 $sql_db = new PDO('mysql:dbname=dbname;host=localhost', 'user', 'pw'); 4 $sql_db->query('SET NAMES utf8'); 5 }

投稿2021/05/29 05:26

編集2021/05/29 12:18
seastar3

総合スコア2285

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

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

m.ts10806

2021/05/29 05:49

クォーテーションが
seastar3

2021/05/29 12:17

m.ts10806さん、 サンクス。さっそく直します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問