PHP设计模式之单例模式(数据库访问)
1.什么是单例模式?
作为对象的创建模式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统全局地提供这个实例。它不会创建实例副本,而是会向单例类内部存储的实例返回一个引用。
2.单例模式的三个要点
A.需要一个保存类的唯一实例的静态成员变量:
private static $_instance;
B.构造函数和克隆函数必须声明为私有的,防止外部程序new类从而失去单例模式的意义:
private function __construct()
{
} private function __clone()
{
}
C.必须提供一个访问这个实例的公共的静态方法(通常为getInstance方法),从而返回唯一实例的一个引用
public static function getInstance(){
if (!(self::$_instance instanceof self)) {
self::$_instance = new self();
}
return self::$_instance;
}
3.为什么要使用单例模式?
A.PHP缺点:
PHP语言是一种解释型的脚本语言,这种运行机制使得每个PHP页面被解释执行后,所有的相关资源都会被回收。也就是说,PHP在语言级别上没有办法让某个对象常驻内存,这和asp.net、Java等编译型是不同的,比如在Java中单例会一直存在于整个应用程序的生命周期里,变量是跨页面级的,真正可以做到这个实例在应用程序生命周期中的唯一性。然而在PHP中,所有的变量无论是全局变量还是类的静态成员,都是页面级的,每次页面被执行时,都会重新建立新的对象,都会在页面执行完毕后被清空,这样似乎PHP单例模式就没有什么意义了,所以PHP单例模式我觉得只是针对单次页面级请求时出现多个应用场景并需要共享同一对象资源时是非常有意义的。
B.单例模式在PHP中的应用场合:
一个应用中会存在大量的数据库操作,比如过数据库句柄来连接数据库这一行为,使用单例模式可以避免大量的new操作,因为每一次new操作都会消耗内存资源和系统资源。
4.应用单例模式对数据库进行操作
/**
* 设计模式之单例模式(单例模式生成一个对象后,此对象可以被众多其它对象所使用)
* 使用场景:最常用的地方是数据库连接。
*
* $_instance 必须声明为 私有的静态变量
* 构造函数和析构函数 必须声明为 私有的,防止外部程序new类,从而失去单例模式的意义(减少内存消耗)
* getInstance()方法必须声明为 公有的,必须调用此方法,以返回实例的一个引用
*
* 知识:1.双冒号操作符(::)只能访问静态变量和静态函数;2.new实例化对象都会消耗内存
*/
class db { private $conn; /**
* 1.静态变量(static),保存全局实例
* 2.私有属性(private),为了避免类外直接 new实例化 调用
*/
private static $sql;
private static $_instance; /** 私有化构造函数,防止外界实例化对象 **/
private function __construct(){ require_once('db.config.php');
$this->conn = mysql_connect($conf['host'], $conf['user'], $conf['password']) OR die(mysql_error());
mysql_select_db($conf['database'], $this->conn) OR die(mysql_error()); mysql_query('SET NAMES '.$conf['charset'].';', $this->conn);
} /** 静态方法,单例访问统一入口 **/
public static function getInstance(){ if (!(self::$_instance instanceof self)) {
self::$_instance = new self();
}
return self::$_instance;
} /** 私有化克隆函数,防止外界克隆对象 **/
private function __clone(){} /** 解析条件语句 **/
private function _parseCondition($condition){ if(is_array($condition)){
$where = '';
foreach($condition as $k => $v){
$where.= "AND `".$k."` = '".$v."' ";
}
$where = '('.trim(ltrim($where, 'AND')).')';
}else{
$where = $condition;
}
return $where;
} /** 解析字段语句 **/
private function _parseFields($fields){ if(is_array($fields)){
$field = '';
foreach($fields as $rs){
$field .= ', `'.$rs.'`';
}
$field = trim(ltrim($field, ','));
}else{
$field = $fields;
}
return $field;
} /** 查询数据库 **/
public function select($table, $condition = array(), $field = array()){ $where = empty($condition) ? '' : ' WHERE '.$this->_parseCondition($condition);
$fields = empty($field) ? '*' : $this->_parseFields($field); self::$sql = 'SELECT '.$fields.' FROM '.$table.$where; $query = mysql_query(self::$sql, $this->conn);
$ary = array();
while($row = mysql_fetch_array($query, MYSQL_ASSOC)){
$ary[] = $row;
}
return $ary;
} /** 返回当前SQL语句 **/
public function getLastSql(){
return self::$sql;
}
}
5.测试代码
header('Content-Type:text/html; Charset=utf-8;');
$db = db::getInstance();
$list = $db->select('table', array(), array());
echo $db->getLastSql();
echo '<pre>';
print_r($list);
echo '</pre>';
注意:记得配置db.config.php的数据库数组值
PHP设计模式之单例模式(数据库访问)的更多相关文章
- 关于PHP建立数据库访问类的封装以及操作php单例模式连接数据库封装类
建立数据库访问类的封装 <?php class DBDA { public $host = "localhost"; //服务器地址 public $ui ...
- 每天一个设计模式-4 单例模式(Singleton)
每天一个设计模式-4 单例模式(Singleton) 1.实际生活的例子 有一天,你的自行车的某个螺丝钉松了,修车铺离你家比较远,而附近的五金店有卖扳手:因此,你决定去五金店买一个扳手,自己把螺丝钉固 ...
- PHP中的设计模式:单例模式(译)
原文链接:http://coderoncode.com/2014/01/27/design-patterns-php-singletons.html 单例模式用于限制类实例化到单个对象,当整个系统只需 ...
- Java设计模式03:常用设计模式之单例模式(创建型模式)
1. Java之单例模式(Singleton Pattern ) 单例模式是一种常见的设计模式,单例模式分三种:懒汉式单例.饿汉式单例.登记式单例三种. 单例模式有一下特点: 1.单例类只能有一个实 ...
- php设计模式之单例模式
单例模式顾名思义,就是只有一个实例.作为对象的创建模式, 单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的要点有三个: 一是某个类只能有一个实例: 二是它必须自行 ...
- php设计模式:单例模式
前些日子开始着真正的去了解下设计模式,开始么,简单地从单例模式开始,当然网上看了一些资料,单例模式比较好理解,看看介绍,然后看看代码基本也就能够理解了,设计模式这些的花点心思基本的是能够理解的,当然要 ...
- python设计模式之单例模式(一)
前言 单例模式是创建模式中比较常见和常用的模式,在程序执行的整个生命周期只存在一个实例对象. 系列文章 python设计模式之单例模式(一) python设计模式之常用创建模式总结(二) python ...
- 数据库访问工具 DBUtl(公孙二狗)
数据库访问工具 DBUtil DBUtil 用于简化数据库的访问,只要准备好配置文件,调用 DBUtil 的静态函数就能直接得到查询数据库的结果. 本文主要内容有: 数据库访问的思考 DBUtil 实 ...
- [PHP]PHP设计模式:单例模式
单例模式(职责模式): 简单的说,一个对象(在学习设计模式之前,需要比较了解面向对象思想)只负责一个特定的任务: 单例类: 1.构造函数需要标记为private(访问控制:防止外部代码使用new操作符 ...
随机推荐
- Android面试必备
好吧,说实话是自己面试被问到的和自己整理的别人的一些问题,很多问题的回答可能根据水平不同层次和深度不同,如果经常忘的话可能是还没明白原理,学习就是对对抗遗忘,现在开始复习吧: 每个面试的问题都极大的贴 ...
- SSAS中CUBE行权限数据级权限控制
去年做了一个数据仓库的项目,其中涉及到了CUBE数据级权限的控制.在网上找这方面的资料,找到一个[BI] 通用数据级权限控制解决方案的实现(二):Cube中的角色设置与数据级权限控制.根据这个大牛的思 ...
- Object-C 重载
方法重载要保证三个条件 1在同一个类中 2.方法参数类型相同 名称相同 3.方法的参数不同 请看下面的例子 @interface whgMyObject : NSObject -(void)print ...
- Struts学习之ValueStack学习
1. 数据传输背后机制:ValueStack(值栈) 在这一切的背后,是因为有了ValueStack(值栈)! ValueStack基础:OGNL OGNL是Struts2中使用的一种表达式语言,它可 ...
- dialog获取焦点
弹出层是一个iframe openWindow:function (options) { var url = options.url; url += url.indexOf("?" ...
- Android Material Design之Toolbar与Palette
转:http://blog.csdn.net/jdsjlzx/article/details/41441083 前言 我们都知道Marterial Design是Google推出的全新UI设计规范,如 ...
- IScroll5+在ios、android点击(click)事件不兼容解决方法
Bug描述: ios.android4.4+下不能触发click事件. Bug解决: 调用iscroll插件,增加配置参数:click:true/false click的值是要根据移动终端设备进行判断 ...
- doT.js 模板引擎的使用
dot.js是一个模板框架,在web前端使用. dot.js作为模板引擎, 主要的用途就是,在写好的模板上,放进数据,生成含有数据的html代码. 这是很简单的web前端模板框架, 简单说几个东西,你 ...
- 以Ajax的方式访问数据库
一:以Ajax的方式显示数据 我们都知道,如果用Ajax程序去加载一个动态页,则加载的实际上是这个动态页执行完毕后生成的静态HTML代码字符串. 1.以原有的格式显示数据 <?php heade ...
- Oracle ORA-01555 快照过旧 说明
oracle高级知识(1) ORA-01555 快照过旧,是数据库中很常见的一个错误,比如当我们的事务需要使用undo来构建CR块的时候,而此时对应的undo 已经不存在了, 这个时候就会报ORA-0 ...