php单例模式连接数据库--代码实现
来源:互联网 发布:centos 7 iso文件太大 编辑:程序博客网 时间:2024/06/01 10:38
单例模式在特定的情况下可以节省资源的消耗,例如同一页面对数据库的多次操作,不需要去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 0
- php单例模式连接数据库--代码实现
- PHP pdo单例模式连接数据库
- PHP 单例模式连接数据库
- 【php】利用单例模式设计数据库连接Model类
- php单例模式连接数据库封装类
- php单例模式连接数据库封装类
- PHP数据库单例模式
- php实现单例模式
- PHP实现单例模式
- PHP实现单例模式
- PHP 单例模式实现
- 单例模式实现数据库
- PHP数据库的连接与代码实现
- PHP面向对象:单态设计模式(连接数据库)
- JDBC连接数据库(单例设计模式)
- JDBC单例模式连接数据库方式
- 单例模式连接数据库实例
- 第四节 单例模式连接数据库
- 软件测试实习0624-testNG异常测试
- android View 的关键生命周期
- selinux(案例) recovery删除data目录下的文件
- 文章标题 Linux下如何重启nginx
- 九大基础排序总结与对比
- php单例模式连接数据库--代码实现
- PAT 1053. 住房空置率 (20)
- 在非UI线程中处理Bitmap
- 依赖倒置 控制反转 依赖注入 (2)
- 强制关机等导致:remounting file system read-only
- 引用类型和基本类型区别
- 使用了 C++ 异常处理程序,但未启用展开语义。请指定 /EHsc
- Retrofit分析与实现
- php导出mysql数据字典