PHP中单例模式连接数据库

Original 2019-06-03 14:07:51 235
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:受连接数量限制, 单例模式的作用很大, 不过, 现在的惰性连接, 已经缓解或杜绝了重复连接的效率问题

Release Notes

Popular Entries