网站首页 > 技术文章 正文
目录
- 概述
- 数据库PDO驱动设计结构图
- 数据库PDO驱动设计代码实战
- 数据库PDO驱动设计完整代码
- php7进阶到架构师相关阅读
概述
这是关于php进阶到架构之php7核心技术与最佳实战学习的第四篇文章:php7魔术方法__call的最佳实战之数据库PDO类的驱动设计实战
- 第一篇:用房子的思维秒懂php7传值与传引用的区别
- 第二篇: php7语法糖好甜,让你迷上php魔术方法
- 第三篇:php7魔术方法__call的最佳实战之链式操作实现
- 第四篇:php7魔术方法__call的最佳实战之数据库PDO类的驱动设计实战
数据库PDO驱动设计结构图
数据库PDO驱动设计代码实战
第一步:实现数据库实现类Mysql,Oracle,和Sqlite
代码如下:
class Mysql{
public function select($sql){
return 'Mysql'.$sql;//模拟数据库查询
}
}
class Oracle{
public function select($sql){
return 'Oracle'.$sql;//模拟数据库查询
}
}
class Sqlite{
public function select($sql){
return 'Sqlite'.$sql;//模拟数据库查询
}
}
第二步:实现数据库的驱动类
$驱动类->select();
驱动类并没有 select 方法,所以触发驱动类 __call() 调用,
然后在__call方法实现对应类调用->select()
驱动类代码实现:
class DbDriver{
private $dbClassName;//数据库类名
public function __construct($dbClassName)
{
//保存数据库类名
$this->dbClassName = $dbClassName;
}
/**
* $驱动类->select($sql),驱动类DbDriver没有select方法,调用__call方法
* @param $name
* @param $arguments
*/
public function __call($name, $arguments)
{
$dbClassName = $this->dbClassName;//类名
$dbClassObj = new $dbClassName ();//创建类对象
$functionName = $name;
//暂不考虑数据类不存在的方法判断
// if(!method_exists($dbClass,$functionName)){
// return false;//未定义该方法
// }
return $dbClassObj->$functionName($arguments[0]);//目前select方法只有一个参数
}
}
PDO代码运行实例:
$dbDriver = new DbDriver('Mysql');
$result = $dbDriver->select('');
echo $result;//输出mysql
$dbDriver = new DbDriver('Oracle');
$result2 = $dbDriver->select('');
echo $result2;//输出Oracle
$dbDriver = new DbDriver('Sqlite');
$result3 = $dbDriver->select('');
echo $result3;//输出Sqlite
如果日后更换了数据驱动,
只需将$dbDriver = new DbDriver('Mysql');
换成$dbDriver = new DbDriver('Sqlite');
就可以了,代码无需做其他改动。
数据库PDO驱动设计完整代码
//数据类实现
class Mysql{
public function select($sql){
return 'Mysql'.$sql;//模拟数据库查询
}
}
class Oracle{
public function select($sql){
return 'Oracle'.$sql;//模拟数据库查询
}
}
class Sqlite{
public function select($sql){
return 'Sqlite'.$sql;//模拟数据库查询
}
}
//PDO驱动类实现
class DbDriver{
private $dbClassName;//数据库类名
public function __construct($dbClassName)
{
//保存数据库类名
$this->dbClassName = $dbClassName;
}
/**
* $驱动类->select($sql),驱动类DbDriver没有select方法,调用__call方法
* @param $name
* @param $arguments
*/
public function __call($name, $arguments)
{
$dbClassName = $this->dbClassName;//类名
$dbClassObj = new $dbClassName ();//创建类对象
$functionName = $name;
//暂不考虑数据类不存在的方法判断
// if(!method_exists($dbClass,$functionName)){
// return false;//未定义该方法
// }
return $dbClassObj->$functionName($arguments[0]);//目前select方法只有一个参数
}
}
//驱动类调用Mysql类
$dbDriver = new DbDriver('Mysql');
$result = $dbDriver->select('');
echo $result;//输出mysql
//驱动类调用Oracle类
$dbDriver = new DbDriver('Oracle');
$result2 = $dbDriver->select('');
echo $result2;//输出Oracle
//驱动类调用Sqlite类
$dbDriver = new DbDriver('Sqlite');
$result3 = $dbDriver->select('');
echo $result3;//输出Sqlite
php7进阶到架构师相关阅读
https://www.kancloud.cn/gofor/gofor
最后,欢迎大家留言补充,讨论~~~
猜你喜欢
- 2025-07-23 国产化红利到底在哪?好多人都在瞎折腾
- 2025-07-23 Oracle 推出 Java 24,增强 AI 支持和后量子加密
- 2025-07-23 JAVA桥接模式适用场景,优缺点是什么你知道吗,这篇文章彻底讲透
- 2025-07-23 SpringBoot条件化配置(@Conditional)全面解析与实战指南
- 2024-10-26 一个前后端分离的Java快速开发平台platform-plus
- 2024-10-26 Oracle-MySQL透明网关配置中关于Driver的坑
- 2024-10-26 pycharm连接数据库失败的解决方法!pycharm连接数据库报错原因!
- 2024-10-26 埃里森炮轰亚马逊AWS不安全,发布Oracle云2.0
- 2024-10-26 JDBC常用的几款数据库驱动程序名及URL
- 2024-10-26 重磅!Spring Boot 2.6 正式发布,一大波新特性,看完我彻底躺平了
你 发表评论:
欢迎- 628℃几个Oracle空值处理函数 oracle处理null值的函数
- 621℃Oracle分析函数之Lag和Lead()使用
- 610℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 604℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 602℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 594℃【数据统计分析】详解Oracle分组函数之CUBE
- 584℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 568℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- oracle 19cOCM认证有哪些内容(oracle认证ocm月薪)
- Oracle新出AI课程认证,转型要持续学习
- oracle 表的查询join顺序,可能会影响查询效率
- Oracle DatabaseAmazon Web Services正式可用,Oracle数据库上云更容易了
- Oracle 19.28 RU 升级最佳实践指南
- 汉得信息:发布EBS系统安装启用JWS的高效解决方案
- 如何主导设计一个亿级高并发系统架构-数据存储架构(三)
- Java 后端开发必看!工厂设计模式轻松拿捏
- ORA-00600 「25027」 「x」报错(抱错孩子电视剧 爸爸是武术 另一个爸爸是画家)
- 新项目终于用上了jdk24(jdk新建项目)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)