abstract:<?php /** * Created by PhpStorm. * 单例模式连接数据库 1、构造函数需要标记为private(访问控制:防止外部代码使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化; 2、拥有一个保存类的实例的静态成员变量 3、拥有一个访问这个实例的公共的静态方法(常用getInsta
<?php /** * Created by PhpStorm. * 单例模式连接数据库 1、构造函数需要标记为private(访问控制:防止外部代码使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化; 2、拥有一个保存类的实例的静态成员变量 3、拥有一个访问这个实例的公共的静态方法(常用getInstance()方法进行实例化单例类,通过instanceof操作符可以检测到类是否已经被实例化) */ class Db { private static $pdo; public static function getPdo () { var_dump(self::$pdo); echo '</br>'; if ( self::$pdo == null ) { $host = '127.0.0.1'; $user = 'root'; $pwd = 'root'; $dbname = 'php_edu'; $dsn = "mysql:host=$host;dbname=$dbname;charset=utf8;port=3306"; $pdo = new PDO ( $dsn, $user, $pwd ); $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); static::$pdo = $pdo; } return static::$pdo; } public static function getStmt ( $sql ) { $pdo = static::getPdo (); return $pdo -> prepare( $sql ); } public static function getinsertids() { $pdo = self::getPdo(); $insertid = $pdo->lastInsertId(); return $insertid; } } $sql = "SELECT * FROM user"; $stmt = Db::getStmt ( $sql ); $stmt = Db::getStmt ( $sql ); ?>
Correcting teacher:天蓬老师Correction time:2019-06-03 16:59:00
Teacher's summary:受连接数量限制, 单例模式的作用很大, 不过, 现在的惰性连接, 已经缓解或杜绝了重复连接的效率问题