私はOOP接続の効率について疑問に思っていました。構造例を以下に示します。各クラスはフォルダとクラス名で区切られています。例えば:
/mysql/mysql.class.php //holds general connect and disconnect functions
/mysql/query.class.php //holds all the queries made to the db (uses basic mysql ^ )
/library/application.class.php //holds all the algorithms (uses queries to db ^ )
アルゴリズムの実行に関しては、接続を要求application.class.php
するquery.class.php
(クエリが必要な場合)mysql.class.php
。
これらの2つの方法のどちらが正しいですか(もしあれば、または両方)?これを行うためのより簡単で効率的な方法はありますか?
これが2つのことを行う同じ方法です(どちらがより効率的ですか??):
require_once('/mysql/mysql.class.php ');
require_once('/mysql/query.class.php ');
$mysqlClass = new MYSQL();
$queryClass = new Query();
class Application {
public function getVar() {
$param = foo;
$db = $mysqlClass->connect(); //connection to mysql
$queryClass->callsomequerymethod($db, $param); //pass the db connection to function
}
}
VS
class Application {
private $db;
public function __construct(DatabaseConnection $db, QueryClass $queryclass){
$this->db = $db;
}
public function getVar() {
$param = foo;
$db = $this->db;
$queryclass->callsomequerymethod($db, $param);
}
}