使用单例模式建立一个数据库连接简单示例
<?php /* *describe:单例模式 数据库类 单例模式的必要条件 (1)私有的构造方法-为了防止在类外使用new关键字实例化对象 (2)私有的成员属性-为了防止在类外引入这个存放对象的属性 (3)私有的克隆方法-为了防止在类外通过clone成生另一个对象 (4)公有的静态方法-为了让用户进行实例化对象的操作 */ header("content-type:text/html;charset=utf-8"); class DbSingleton { private $charset = "utf8"; //字符串编码 //私有的成员属性-为了防止在类外引入这个存放对象的属性 private static $instance = NULL; //存储对象 //私有的构造方法-为了防止在类外使用new关键字实例化对象 private function __construct($host, $username, $password, $dbname, $port) { $link = mysqli_connect($host, $username, $password, $dbname, $port); if (!$link) { die("连接错误: " . mysqli_connect_error()); } // 修改数据库连接字符集为 utf8 mysqli_set_charset($link, $this->charset); return $link; } //私有的克隆方法-为了防止在类外通过clone成生另一个对象 private function __clone() { } //公有的静态方法-为了让用户进行实例化对象的操作 public static function getInstance($host, $username, $password, $dbname, $port) { if (!self::$instance instanceof self) { self::$instance = new self($host, $username, $password, $dbname, $port); } return self::$instance; } } //测试: //$host = '127.0.0.1'; //$username = 'root'; //$password = '123456'; //$dbname = 'test'; //$port = 3306; //$db = DbSingleton::getInstance($host, $username, $password, $dbname, $port); //var_dump($db);
=======================================
由于本人水平有限,文章在表述和代码方面如有不妥之处,欢迎批评指正。留下你的脚印,欢迎评论哦。你也可以关注我,一起学习哦!