首頁 後端開發 php教程 用单例模式来设计一个PHP数据库类_PHP教程

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

Jul 13, 2016 am 10:33 AM
單例模式

最近感觉网站的数据库压力比较大,造成网站的速度下降得很厉害。因为有相当一部分的页面是直接连接数据库读数据的,所以把这部分的页面也改为使用数据库单例类来实现。现在基本都统一使用下面这个类来连接数据库了。

<?php
class 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';
}
?>
登入後複製

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/752473.htmlTechArticle最近感觉网站的数据库压力比较大,造成网站的速度下降得很厉害。因为有相当一部分的页面是直接连接数据库读数据的,所以把这部分的...
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

一文理解JavaScript中的單例模式 一文理解JavaScript中的單例模式 Apr 25, 2023 pm 07:53 PM

JS 單例模式是常用的設計模式,它可以保證一個類別只有一個實例。這種模式主要用於管理全域變量,避免命名衝突和重複加載,同時也可以減少記憶體佔用,提高程式碼的可維護性和可擴展性。

C++ 函式重載與重寫中單例模式與工廠模式的運用 C++ 函式重載與重寫中單例模式與工廠模式的運用 Apr 19, 2024 pm 05:06 PM

單例模式:透過函數重載提供不同參數的單例實例。工廠模式:透過函數重寫建立不同類型的對象,實現創建過程與特定產品類別的解耦。

PHP入門指南:單例模式 PHP入門指南:單例模式 May 20, 2023 am 08:13 AM

在軟體開發中,常常遇到多個物件需要存取同一個資源的情況。為了避免資源衝突以及提高程式的效率,我們可以使用設計模式。其中,單例模式是一種常用的創建物件的方式,即保證一個類別只有一個實例,並提供全域存取。本文將為大家介紹如何使用PHP實作單例模式,並提供一些最佳實務的建議。一、什麼是單例模式單例模式是一種常用的創建物件的方式,它的特點是保證一個類別只有一個實例,並提

PHP中單例模式的線程安全性問題思考 PHP中單例模式的線程安全性問題思考 Oct 15, 2023 am 10:14 AM

PHP中單例模式的線程安全性問題思考在PHP程式設計中,單例模式是一種常用的設計模式,它可以確保一個類別只有一個實例,並且提供一個全域的存取點來存取這個實例。然而,在多執行緒環境下使用單例模式時,需要考慮線程安全性的問題。單例模式的最基本實作包括一個私有的建構子、一個私有的靜態變數和一個公有的靜態方法。具體程式碼如下:classSingleton{pr

在PHP中,單例設計模式是什麼概念? 在PHP中,單例設計模式是什麼概念? Aug 18, 2023 pm 02:25 PM

Singleton模式確保一個類別只有一個實例,並提供了一個全域的存取點。它確保在應用程式中只有一個物件可用,並處於受控狀態。 Singleton模式提供了一種訪問其唯一物件的方式,可以直接訪問,而無需實例化類別的物件。範例&lt;?php  classdatabase{   publicstatic$connection;   privatefunc

PHP 設計模式:通往程式碼卓越的道路 PHP 設計模式:通往程式碼卓越的道路 Feb 21, 2024 pm 05:30 PM

導言PHP設計模式是一組經過驗證的解決方案,用於解決軟體開發中常見的挑戰。透過遵循這些模式,開發者可以創建優雅、健壯和可維護的程式碼。它們可協助開發者遵循SOLID原則(單一職責、開放-封閉、Liskov替換、介面隔離和依賴反轉),從而提高程式碼的可讀性、可維護性和可擴展性。設計模式的類型有許多不同的設計模式,每種模式都有其獨特的目的和優點。以下是一些最常用的php設計模式:單例模式:確保一個類別只有一個實例,並提供一種全域存取此實例的方法。工廠模式:建立一個對象,而不指定其確切類別。它允許開發者根據條件

單例模式在PHP框架中的擴展與定制 單例模式在PHP框架中的擴展與定制 Oct 15, 2023 am 11:10 AM

單例模式在PHP框架中的擴展與自訂【引言】單例模式是一種常見的設計模式,它保證類別在整個應用程式中只能實例化一次。在PHP開發中,單例模式的應用非常廣泛,特別是在框架的開發和擴展。本文將介紹如何在PHP框架中擴展和自訂單例模式,並提供具體的程式碼範例。 【什麼是單例模式】單例模式是指一個類別只能有一個物件實例存在,並提供一個全域存取點供外部使用。在PHP開發中,通

揭秘 PHP 設計模式的奧秘 揭秘 PHP 設計模式的奧秘 Feb 21, 2024 pm 01:19 PM

1.什麼是PHP設計模式? PHP設計模式是預先定義的程式碼模板,旨在解決常見的軟體開發問題。它們提供了經過驗證的解決方案,可以提高程式碼的可重複使用性、可維護性和可擴充性。 2.PHP設計模式的類型php中有許多不同的設計模式,每種模式都有其特定的用途。最常見的模式包括:單例模式:確保一個類別只有一個實例。工廠模式:根據傳給它的資料建立不同類型的物件。策略模式:允許程式在運行時更改其行為。觀察者模式:允許物件訂閱事件並在事件發生時獲得通知。 3.單例模式範例classSingleInstance{private

See all articles