mat*_*att 5 php mysql oop singleton class
我正在尝试创建一个简单的使用单例类连接到mysql数据库并进行查询,代码工作正常,我没有遇到任何问题,但因为我是OOP的新手,我想知道这是否是不好的做法.
这是班级
class Database {
private $databaseName = 'dbname';
private $host = 'localhost';
private $user = 'user';
private $password = 'pass';
private static $instance; //store the single instance of the database
private function __construct(){
//This will load only once regardless of how many times the class is called
$connection = mysql_connect($this->host, $this->user, $this->password) or die (mysql_error());
$db = mysql_select_db($this->databaseName, $connection) or die(mysql_error());
echo 'DB initiated<br>';
}
//this function makes sure there's only 1 instance of the Database class
public static function getInstance(){
if(!self::$instance){
self::$instance = new Database();
}
return self::$instance;
}
public function connect() {
//db connection
}
public function query($query) {
//queries
$sql = mysql_query($query) or die(mysql_error());
return $sql;
}
public function numrows($query) {
//count number of rows
$sql = $this->query($query);
return mysql_num_rows($sql);
}
}
//Intantiate the class
$database = Database::getInstance();
Run Code Online (Sandbox Code Playgroud)
当我想使用我会做的课时:
$query = "SELECT * FROM registrations";
echo $database->numrows($query);
$sql = $database->query($query);
Run Code Online (Sandbox Code Playgroud)
Gor*_*onM 12
单身人士是坏消息.
你最好再看看依赖注入,因为它解决了上述问题.
归档时间: |
|
查看次数: |
14558 次 |
最近记录: |