博客列表 >php之单例模式连接数据库

php之单例模式连接数据库

月光下,遗忘黑暗
月光下,遗忘黑暗原创
2021年05月08日 22:07:58935浏览

代码块

<?php/** * PHP语言是一种解释型的脚本语言,这种运行机制使得每个PHP页面被解释执行后,所有的相关资源都会被回收。也就是说,PHP在语言级别上没有办法让某个对象常驻内存,这和asp.net、Java等编译型是不同的,比如在Java中单例会一直存在于整个应用程序的生命周期里,变量是跨页面级的,真正可以做到这个实例在应用程序生命周期中的唯一性。然而在PHP中,所有的变量无论是全局变量还是类的静态成员,都是页面级的,每次页面被执行时,都会重新建立新的对象,都会在页面执行完毕后被清空,这样似乎PHP单例模式就没有什么意义了 * */ //PHP单例模式只是针对单次页面级请求时,出现多个应用场景并需要共享同一对象资源时是非常有意义的。/** * 面向对象编程三大特性: * 1. 封装 可见性  php中使用3种类型的可见性 : private(私有), protected(保护),public(公共) * 封装一个程序元素, 把它设为private,仅在本类中可见,还可以把它设为protected,允许本类及其子类访问该属性; 要访问封装的对象, 必须提供公有的可见性. 想要作为一个真正有用的类, 必须至少提供一些方法是可见的(即使只是构造函数) *  *  * 2. 继承 inheritance * 一个类扩展另一个类,前者会拥有后者的所有属性和方法. * php oop具有单继承的特点 -> 带来程序的高耦合性:如果程序通过深层次继承绑定到具体类,即使对父类做简单的修改,也会对子类带来严重的破坏 -> 解决办法: 1. 为了保证类之间的松绑定,通常会继承抽象类,而且是浅继承,即只有一层子类. 2. 引入trait结构 *  *  * 3. 多态 polymorphism  多态只有在oop上下文中讨论才有意义,多态真正价值在于,可以调用有相同接口的对象完成不同的工作.   基于一个公共接口, 在一个给定的程序结构中做出修改或增补时, 可以放心递请求或使用接口方法而不必担心程序会崩溃  一个名字多个实现 *  *  * 接口通常允许开发人员创建松绑定的对象和类,php接口允许储存常量,实现接口的类都可以使用接口中储存的常量 */ //单例模式连接数据库  应用程序与数据库交互 interface iDbBase {    //  数据库操作  curd     static function insert($db);    static function select($db,$where=[]);    static function delete($db,$where=[]);    static function update($db,$data,$where);    static function doConnect($dsn,$username,$password);    // return $this;实现链式调用 } //使用单例模式连接数据库 abstract class aDb implements iDbBase {     //创建类的唯一实例 唯一对象     private static $instance;//保存返回的pdo连接对象     //private关键字 阻止此类在外部进行实例化     private function __construct()     {     }     //private关键字阻止此类在外部进行克隆     private function __clone()     {     }     //只能由类的自身 来进行实例化      static function doConnect($dsn,$username,$password){        //判断$instance是否是aDb类的对象        if(is_null(self::$instance))         {            // echo 'aaaa';            //实例化本类, 传入连接参数,             self::$instance = new PDO($dsn,$username,$password);        }        return self::$instance;    } } //客户端代码// $config = [//     'type'=> $type ?? 'mysql',//     'host'=> $host ?? 'localhost',//     'dbname'=> $dbname ?? 'news',//     'username'=> $username ?? 'root',//     'password'=> $password ?? 'zhoujielun521'// ];// $dsn = sprintf('%s:host=%s;dbname=%s',$config['type'],$config['host'],$config['dbname']);// $username = $config['username'];// $password = $config['password'];// // aDb::doConnect($dsn,$username,$password);// for ($i=0; $i < 10; $i++) { //     aDb::doConnect($dsn,$username,$password);// }//工作类class Db extends aDb{     //  数据库操作  curd      static function insert($db)     {        return $db->query('insert into `admins`(`username`,`password`,`truename`,`gid`,`add_time`) value("asd","fdsa","dsadsas",2,4213) ')->fetchAll(PDO::FETCH_ASSOC);     }     static function select($db,$where=[])     {        return $db->query('SELECT * FROM `iuser` LIMIT 3')->fetchAll(PDO::FETCH_ASSOC);     }     static function delete($db,$where=[])     {     }     static function update($db,$data,$where)     {     }}//客户端代码$config = [    'type'=> $type ?? 'mysql',    'host'=> $host ?? 'localhost',    'dbname'=> $dbname ?? 'video',    'username'=> $username ?? 'root',    'password'=> $password ?? 'root'];$dsn = sprintf('%s:host=%s;dbname=%s',$config['type'],$config['host'],$config['dbname']);$username = $config['username'];$password = $config['password'];//获取pdo连接对象$db = Db::doConnect($dsn,$username,$password);echo '<pre>';print_r(Db::insert($db,));

效果

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议