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

单例模式在特定的情况下可以节省资源的消耗,例如同一页面对数据库的多次操作,不需要去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();
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值