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() という関数は、正常にデータベースに接続されるのか?を知りたいです。
※ 現状、接続できずにエラーが出ています。
また、上記のような場合に、もっと正しいデータベース接続箇所があれば、教えて頂きたいです。
※ フレームワーク等は使わずに、勉強のために知りたいです。
すみません、上記コードでは情報が足りないかもしれませんが、お分かりになる範囲で教えて頂けると幸いです。
どうぞ宜しくお願い申し上げます。