php单例模式连接数据库--代码实现

时间:2022-12-11 12:19:24

单例模式在特定的情况下可以节省资源的消耗,例如同一页面对数据库的多次操作,不需要去new多次从而节省了资源。
单例模式的关键在于php中的“instanceof”,它用来检测一个变量是否是某个类的一个实例。
同时,为了防止用户去new实例,需要将“__construct”函数权限设置为private。
为了防止用户进行clone,也要重写“__clone”方法。

<?php
/*
* 单例数据库连接
*/

class Db {
private static $_instance; //static可以保存值不丢失
private static $_dbConnect;
private $_dbConfig = array(
'host' => '127.0.0.1',
'user' => 'root',
'password' => '',
'database' => 'yii2basic',
);//保存数据库的配置信息

//使用private防止用户new
private function __construct(){

}

//重写clone防止用户进行clone
public function __clone(){
//当用户clone操作时产生一个错误信息
trigger_error("Can't clone object",E_USER_ERROR);
}

//由类的自身来进行实例化
public static function getInstance(){
if(!(self::$_instance instanceof self)){
self::$_instance = new self();
}
return self::$_instance;
}

public function connect(){
self::$_dbConnect = @mysql_connect($this->_dbConfig['host'],
$this->_dbConfig['user'],$this->_dbConfig['password']);

if(!self::$_dbConnect){
throw new Exception("mysql connect error".mysql_error());
//die("mysql connect error".mysql_error());
}

mysql_query("SET NAMES UTF8");
mysql_select_db($this->_dbConfig['database'],self::$_dbConnect);
return self::$_dbConnect;
}
}

$a = Db::getInstance();
try{
$a->connect();
}catch(Exception $e){
echo "sorry,error was happend.".$e->getMessage();
}