将各种截然不同的函数接口封装成统一的api。
php中的数据库操作有mysql,mysqli,pdo三种,可以用适配器模式统一成一致,使不同的数据库操作,统一成一样的api。类似的场景还有cache适为他人着想配器,可以将memcache,redis,file,apc等不同的缓存函数,统一成一致。
首先定义一个接口(有几个方法,以及相应的参数)。然后,有几种不同的情况,就写几个类实现该接口。将完成相似功能的函数,统一成一致的方法。
创建接口imooc/databa.php
在imooc/databa文件创建 mysql.php mysqli.php pdo.php
//接口 idataba<?phpnamespace databa;interface idataba{ function connect($host, $ur, $passwd, $dbname); function query($sql); function clo();}
mysql<?phpnamespace imooc\databa;u imooc\idataba;class mysql implements idataba{ protected $conn; function connect($host, $ur, $passwd, $dbname) { $conn = mysql_connect($host, $ur, $passwd); mysql_lect_db($dbname, $conn); $this->conn = $conn; } function query($sql) { $res = mysql_query($sql, $this->conn); return $res; } function clo() { mysql_clo($this->conn); }}
mysqli<?phpnamespace imooc\databa;u imooc\idataba;class mysqli implements idataba剪纸英文{ protected $结尾摘抄conn; function connect($host, $ur, $passwd, $dbname) { $conn = mysqli_connect($host, $ur, $passwd, $dbname); $this->conn = $conn; } function query($sql) { return mysqli_query($this->conn, $sql); } function clo() { mysqli_clo($this->conn); }}
pdo<?php钢铁是怎样炼成的电视剧namespace imooc\databa;u imooc\idataba;class pdo implements idataba{ protected $conn; function connect($host, $ur, $passwd, $dbname) { $conn = new \pdo("mysql:host=$host;dbname=$dbname", $ur, $passwd); $this->conn = $conn; }function query($s象限角的取值范围ql) { return $this->conn->query($sql); } function clo() { unt($this->conn); }}
本文发布于:2023-04-07 12:24:41,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/cca1bcd5a163579e4ee6f1ac8b9b04cc.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:php设计模式之适配器模式.doc
本文 PDF 下载地址:php设计模式之适配器模式.pdf
留言与评论(共有 0 条评论) |