php之单例模式连接数据库
16lz
2021-05-09
代码块
<?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,));
效果
更多相关文章
- SpringBoot 项目配置 Swagger 接口api 搭建 REST
- 【PHP 面向对象】面向对象(OOP)编程知识点归纳总结(一)
- <JVM下篇:性能监控与调优篇>补充:使用OQL语言查询对象信息
- <JVM下篇:性能监控与调优篇>补充:浅堆深堆与内存泄露
- Python如何进行内存管理?
- Pandas Series对象有哪些属性?六大类!
- 1.jsp 三大指令 六大标签 九大内置对象 四大作用域
- 03-Vue_样式设置
- 序列化框架的选型和比对