Heim >Backend-Entwicklung >PHP-Tutorial >Der PHP-Singleton-Modus entwirft eine Datenbank und stellt eine Verbindung zur Model-Klasse her

Der PHP-Singleton-Modus entwirft eine Datenbank und stellt eine Verbindung zur Model-Klasse her

小云云
小云云Original
2018-03-29 10:53:041713Durchsuche

Mithilfe der im „[Java] Singleton-Modus“ eingeführten Idee (klicken Sie hier, um den Link zu öffnen) kann diese Datenbank-Link-Klasse in einen Singleton umgewandelt werden, nur weil mehrere Benutzer darauf zugreifen Drag-and-Drop Durch die Verlangsamung der Geschwindigkeit der gesamten Website wird die Datenbank der Website stärker belastet, was dazu führt, dass die Geschwindigkeit der Website erheblich abnimmt.

Die kritischsten Aspekte der Singleton-Implementierung sind die drei Punkte:

Ein privater Konstruktor ohne Parameter ist nicht erforderlich Es sind mehrere Konstruktoren zulässig – auch wenn die Konstruktorparameter unterschiedlich sind.

2. Funktionen privater Klonklassen

3. Stellen Sie eine öffentliche „Instanzfunktion erstellen“ zur Verfügung, um festzustellen, ob die entsprechende Instanz bereits vorhanden ist. Erstellen Sie, wenn keine vorhanden sind.

Dadurch wird sichergestellt, dass es nur eine Datenbankverbindungsklasse gibt.

Verwenden Sie zur direkten Veranschaulichung einen Tabellenbenutzer.


Verwenden Sie zunächst den Singleton-Modus, um die Datenbankverbindung zu entwerfen Modellklasse und fügen Sie dies hinzu. Der Inhalt der Tabelle wird auf der Webseite abgefragt:


  1. <?php  
    class db{  
        private $link;  
        //db类单例开始  
        //保存类实例的私有静态成员变量  
        private static $_instance;  
        //定义一个私有的构造函数,确保单例类不能通过new关键字实例化,只能被其自身实例化  
        private function __construct($host,$username,$password,$database){  
            $this->link=mysql_connect($host,$username,$password);  
            if(!$this->link){  
                die("连接失败!");  
            }  
            mysql_query("set names utf8;");  
            mysql_select_db($database);  
        }  
        //定义私有的__clone()方法,确保单例类不能被复制或克隆  
        private function __clone(){}  
        public static function getInstance($host, $username, $password,$database) {  
            //检测类是否被实例化  
            if(!(self::$_instance instanceof self)){  
                self::$_instance=new db($host,$username,$password,$database);  
            }  
            return self::$_instance;  
        }  
        //执行SQL语句  
        public function query($query){  
            return mysql_query($query, $this->link);  
        }  
        //关闭数据库连接  
        public function close(){  
            return mysql_close($this->link);  
        }  
    }  
    //调用单例类测试部分  
    header("Content-type: text/html; charset=utf-8"); //设置网页编码  
    $dbconnector=db::getInstance("localhost","root","root","test");//创建数据库连接类  
    $result=$dbconnector->query("select * from user");//查询数据库  
    for($i=0;$row=mysql_fetch_array($result);$i++){//打印查询结果  
        echo $row[&#39;id&#39;].",".$row[&#39;username&#39;].",".$row[&#39;password&#39;]."<br/>";  
    }    
    ?>


Dies garantiert, dass es nur eine Instanz $dbconnector gibt, die der Klasse db entspricht, und es gibt einen weiteren Satz:

  1. $dbconnector1
    =db::getInstance(
    "localhost"
    ,
    "root"
    ,
    "root"
    ,
    "test"
    );
    //创建数据库连接类


Es passiert immer noch. Rückkehr zur ursprünglich erstellten Instanz $dbconnector Es sollte gesagt werden, dass die Bedienung von $dbconnector und $dbconnector1 die gleiche Wirkung hat. Es werden keine weiteren Ressourcen zugewiesen Speicher zum Speichern von $dbconnector und $dbconnector1, da die Datenbank ein einzelnes Beispiel ist, wodurch der Zweck der Reduzierung des Datenbankdrucks erreicht wird.

Verwandte Empfehlungen:

Erfahrung im Entwerfen von Datenbanken_PHP-Tutorial

Das obige ist der detaillierte Inhalt vonDer PHP-Singleton-Modus entwirft eine Datenbank und stellt eine Verbindung zur Model-Klasse her. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn