백엔드 개발 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 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

JavaScript의 싱글톤 패턴을 이해하기 위한 기사 1개 JavaScript의 싱글톤 패턴을 이해하기 위한 기사 1개 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를 사용하여 싱글톤 패턴을 구현하는 방법을 소개하고 몇 가지 모범 사례 제안을 제공합니다. 1. 싱글턴 모드란 무엇입니까? 싱글턴 모드는 객체를 생성하는 데 일반적으로 사용되는 방법으로, 클래스에 인스턴스가 하나만 있도록 보장하고 제공하는 것이 특징입니다.

PHP에서 싱글턴 디자인 패턴의 개념은 무엇입니까? PHP에서 싱글턴 디자인 패턴의 개념은 무엇입니까? Aug 18, 2023 pm 02:25 PM

싱글톤 패턴은 클래스에 인스턴스가 하나만 있고 전역 액세스 지점을 제공하도록 보장합니다. 이는 애플리케이션에서 하나의 객체만 사용 가능하고 제어되도록 보장합니다. 싱글톤 패턴은 클래스의 개체를 인스턴스화하지 않고 고유한 개체에 직접 액세스하는 방법을 제공합니다. 예&lt;php classdatabase{ publicstatic$connection;

PHP 디자인 패턴: 코드 우수성을 향한 길 PHP 디자인 패턴: 코드 우수성을 향한 길 Feb 21, 2024 pm 05:30 PM

소개 PHP 디자인 패턴은 소프트웨어 개발의 일반적인 과제에 대한 입증된 솔루션 세트입니다. 이러한 패턴을 따르면 개발자는 우아하고 강력하며 유지 관리가 가능한 코드를 만들 수 있습니다. 이는 개발자가 SOLID 원칙(단일 책임, 개방형 폐쇄형, Liskov 대체, 인터페이스 격리 및 종속성 반전)을 따르도록 지원하여 코드 가독성, 유지 관리성 및 확장성을 향상시킵니다. 디자인 패턴의 유형 다양한 디자인 패턴이 있으며 각각 고유한 목적과 장점을 가지고 있습니다. 다음은 가장 일반적으로 사용되는 PHP 디자인 패턴 중 일부입니다. 싱글톤 패턴: 클래스에 인스턴스가 하나만 있는지 확인하고 이 인스턴스에 전역적으로 액세스할 수 있는 방법을 제공합니다. 팩토리 패턴: 정확한 클래스를 지정하지 않고 객체를 생성합니다. 개발자는 조건부로

PHP 분산 시스템에서 싱글톤 모드의 애플리케이션 시나리오 및 스레드 안전 프로세스 PHP 분산 시스템에서 싱글톤 모드의 애플리케이션 시나리오 및 스레드 안전 프로세스 Oct 15, 2023 pm 04:48 PM

PHP 분산 시스템에서 싱글톤 모드의 애플리케이션 시나리오 및 스레드 안전 프로세스 소개: 인터넷의 급속한 발전으로 분산 시스템은 현대 소프트웨어 개발에서 뜨거운 주제가 되었습니다. 분산 시스템에서 스레드 안전성은 항상 중요한 문제였습니다. PHP 개발에서 싱글톤 패턴은 일반적으로 사용되는 디자인 패턴으로 리소스 공유 및 스레드 안전 문제를 효과적으로 해결할 수 있습니다. 이 기사에서는 PHP 분산 시스템에서 싱글톤 패턴의 애플리케이션 시나리오 및 스레드 안전 프로세스에 중점을 두고 특정 코드 예제를 제공합니다. 1. 싱글톤 모드

PHP 디자인 패턴의 비밀을 찾아보세요 PHP 디자인 패턴의 비밀을 찾아보세요 Feb 21, 2024 pm 01:19 PM

1. PHP 디자인 패턴이란 무엇입니까? PHP 디자인 패턴은 일반적인 소프트웨어 개발 문제를 해결하도록 설계된 사전 정의된 코드 템플릿입니다. 코드 재사용성, 유지 관리성 및 확장성을 향상시키는 검증된 솔루션을 제공합니다. 2. PHP 디자인 패턴의 유형 PHP에는 다양한 디자인 패턴이 있으며 각 패턴에는 특정 목적이 있습니다. 가장 일반적인 패턴은 다음과 같습니다. 싱글톤 패턴: 클래스의 인스턴스가 하나만 있는지 확인합니다. 팩토리 패턴: 전달된 데이터를 기반으로 다양한 유형의 객체를 생성합니다. 전략 모드: 프로그램이 런타임 시 동작을 변경할 수 있도록 합니다. 관찰자 패턴: 객체가 이벤트를 구독하고 이벤트가 발생할 때 알림을 받을 수 있습니다. 3. 싱글톤 모드 예시 classSingleInstance{private

PHP의 싱글톤 패턴의 일반적인 애플리케이션 시나리오 분석 PHP의 싱글톤 패턴의 일반적인 애플리케이션 시나리오 분석 Oct 15, 2023 pm 01:25 PM

PHP의 싱글톤 패턴에 대한 일반적인 애플리케이션 시나리오 분석 개요: 싱글톤 패턴(SingletonPattern)은 클래스에 인스턴스가 하나만 있음을 보장하고 인스턴스에 액세스할 수 있는 전역 액세스 지점을 제공하는 생성 디자인 패턴입니다. PHP에서 싱글톤 모드를 사용하면 클래스의 인스턴스화 수와 리소스 사용량을 효과적으로 제한하고 코드의 성능과 유지 관리성을 향상시킬 수 있습니다. 이 기사에서는 일반적인 애플리케이션 시나리오를 분석하고 특정 PHP 코드 예제를 제공하여 싱글톤 패턴의 사용과 이점을 설명합니다. 데이터베이스 연결 파이프

See all articles