用单例模式来设计一个PHP数据库类
来源:互联网 发布:删除表数据 sql 编辑:程序博客网 时间:2024/05/11 14:29
<?phpclass nmdb {private $link;static private $_instance;// 连接数据库private function __construct($host, $username, $password){$this->link = mysql_connect($host, $username, $password);$this->query("SET NAMES 'utf8'", $this->link);//echo mysql_errno($this->link) . ": " . mysql_error($link). "n";//var_dump($this->link);return $this->link;}private function __clone(){}public static function get_class_nmdb($host, $username, $password){ //$connector = new nmdb($host, $username, $password); //return $connector;if( FALSE == (self::$_instance instanceof self) ){self::$_instance = new self($host, $username, $password);}return self::$_instance; }// 连接数据表public function select_db($database){$this->result = mysql_select_db($database);return $this->result;}// 执行SQL语句public function query($query){return $this->result = mysql_query($query, $this->link);}// 将结果集保存为数组public function fetch_array($fetch_array){return $this->result = mysql_fetch_array($fetch_array, MYSQL_ASSOC);}// 获得记录数目public function num_rows($query){return $this->result = mysql_num_rows($query);}// 关闭数据库连接public function close(){return $this->result = mysql_close($this->link);}}?>
这个类的使用如下:
$connector = nmdb::get_class_nmdb($host, $username, $password);$connector -> select_db($database);
下面的类也可以参考下:
<?php/** mysql 单例*/class mysql{ private $host ='localhost'; //数据库主机 private $user = 'root'; //数据库用户名 private $pwd = ''; //数据库用户名密码 private $database = 'imoro_imoro'; //数据库名 private $charset = 'utf8'; //数据库编码,GBK,UTF8,gb2312 private $link; //数据库连接标识; private $rows; //查询获取的多行数组 static $_instance; //存储对象 /** * 构造函数 * 私有 */ private function __construct($pconnect = false) { if (!$pconnect) { $this->link = @ mysql_connect($this->host, $this->user, $this->pwd) or $this->err(); } else { $this->link = @ mysql_pconnect($this->host, $this->user, $this->pwd) or $this->err(); } mysql_select_db($this->database) or $this->err(); $this->query("SET NAMES '{$this->charset}'", $this->link); return $this->link; } /** * 防止被克隆 * */ private function __clone(){} public static function getInstance($pconnect = false){ if(FALSE == (self::$_instance instanceof self)){ self::$_instance = new self($pconnect); } return self::$_instance; } /** * 查询 */ public function query($sql, $link = '') { $this->result = mysql_query($sql, $this->link) or $this->err($sql); return $this->result; } /** * 单行记录 */ public function getRow($sql, $type = MYSQL_ASSOC) { $result = $this->query($sql); return @ mysql_fetch_array($result, $type); } /** * 多行记录 */ public function getRows($sql, $type = MYSQL_ASSOC) { $result = $this->query($sql); while ($row = @ mysql_fetch_array($result, $type)) { $this->rows[] = $row; } return $this->rows; } /** * 错误信息输出 */ protected function err($sql = null) { //这里输出错误信息 echo 'error'; exit(); }}//用例$db = mysql::getInstance();$db2 = mysql::getInstance();$data = $db->getRows('select * from blog');//print_r($data);//判断两个对象是否相等if($db === $db2){ echo 'true';}?>
0 0
- 用单例模式来设计一个PHP数据库类
- PHP用单例模式实现一个数据库类
- PHP用单例模式实现一个数据库类
- 用单例模式写一个php数据库管理类
- php 设计模式(数据库对象模式)
- 【php】利用单例模式设计数据库连接Model类
- 用单例模式封装实现一个数据库类
- php 类and设计模式
- 一个PHP数据库基类
- 定义一个类来连接操作数据库
- PHP设计模式——封装Mysql数据库
- PHP面向对象:单态设计模式(连接数据库)
- php 设计模式-数据映射模式(应用程序与数据库交互模式)
- php数据库模式设计、数据库访问和使用数据库的业务逻辑解决方案
- php 抽象类 静态 单体设计模式
- [php]php设计模式 (总结)
- php设计模式
- php 观察者设计模式
- LeetCode | Word Break
- 自写打印日历类
- map-reduce的八个流程
- AbstractQueuedSynchronizer实现源码解析(三)
- javascript变量作用域
- 用单例模式来设计一个PHP数据库类
- 仪器、界面水有多深(2)
- seekbar介绍及其例子
- BST小结
- Linux学习笔记——例说makefile 多个文件
- AQS
- uva 10194 Football (字符结构体排序)
- UI笔记_视图控制器UIViewController
- android 开发故障记录