您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息
三六零分类信息网 > 兰州分类信息网,免费分类信息发布

用单例模式来设计一个PHP数据库类_PHP教程

2024/4/27 21:39:59发布9次查看
最近感觉网站的数据库压力比较大,造成网站的速度下降得很厉害。因为有相当一部分的页面是直接连接数据库读数据的,所以把这部分的页面也改为使用数据库单例类来实现。现在基本都统一使用下面这个类来连接数据库了。
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);
下面的类也可以参考下:
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';}?>
http://www.bkjia.com/phpjc/752473.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/752473.htmltecharticle最近感觉网站的数据库压力比较大,造成网站的速度下降得很厉害。因为有相当一部分的页面是直接连接数据库读数据的,所以把这部分的...
兰州分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录