我们可能会遇到这种情况,为了实现一些业务逻辑,我们会对同一个对象来回重建进行业务处理
比如说做试卷,老师除了一套试卷,学生们拿到试卷只有两个地方不一样,填写的答案和名字
这样的话,整体的算法骨架是一定的,你只需要固定出来一套题就可以,子类去修改其中一两部
应用情境:数据库中间层的抽象类
上代码
<?php
//模板设计模式创建了一个实施一组方法的抽象对象,子类通常将这个对象作为模板用于自己的设计。
//一般会用于数据库抽象类。
abstract class dbbaseInit{
/**
* 抽象数据库链接
* @param string $host sql服务器
* @param string $user 数据库用户名
* @param string $password 数据库登录密码
* @param string $database 数据库
* @param string $charset 编码
* @param string $pconnect 是否持久链接
*/
abstract protected function connect($host,$user,$password,$database,$charset='utf-8',$pconnect=0);
/**
* 抽象数据库执行语句
* @param string $sql SQL语句
* @return obj
*/
abstract protected function query($sql);
/**
* 抽象数据库-结果集中的行数
* @param $result 结果集
* @return array
*/
abstract protected function result($result,$num=1);
/**
* 抽象数据库-从结果集中取得一行作为关联数组
* @param $result 结果集
* @return array
*/
//这个方法没用过(不是数字索引而是字段)
abstract protected function fetch_assoc($result);
/**
* 抽象数据库-从结果集中取得列信息并作为对象返回
* @param $result 结果集
* @return array
*/
abstract protected function fetch_fields($result);
/**
* 抽象数据库-前一次操作影响的记录数
* @return int
*/
//这个也没有用过
abstract protected function affected_rows();
/**
* 抽象数据库-结果集中的行数
* @param $result 结果集
* @return int
*/
abstract protected function num_rows($result);
/**
* 抽象数据库-结果集中的字段数量
* @param $result 结果集
* @return int
*/
abstract protected function num_fields($result);
/**
* 抽象数据库-获取上一INSERT的ID值
* @return Int
*/
abstract protected function insert_id();
/**
* 抽象数据库-释放结果内存
* @param obj $result 需要释放的对象
*/
abstract protected function free_result($result);
/**
* 抽象数据库链接关闭
* @param string $sql SQL语句
* @return obj
*/
abstract protected function close();
/**
* 错误信息
* @return string
*/
abstract protected function error();
}
//这是具体的某个数据库,比如MySQL,oracle
class mysqliInit extends dbbaseInit{
public $link_id;
//重写模型中的连接类
public function connect($host,$user,$password,$database,$charset='utf8',pconnect=0){
$link_id = ($pconnect==0)?mysqli_connect($host,$user,$password):mysqli_pconnect($host,$user,$password);
if(!$link_id) die('mysql connect error!');
mysql_query($link_id,'set names'.$charset);
if(!mysqli_select_db($link_id,$database)) die('database is not exist');
return $link_id;
}
public function query($sql){
return mysqli_query($this->link_id,$sql);
}
public function result($result,$num=1){
return mysqli_result($result,$num);
}
public function fetch_assoc($result){
return mysqli_fetch_assoc($result);
}
public function fetch_fields($result){
return mysqli_num_fields($result);
}
public function free_result($result){
return mysqli_free_result($result);
}
public function insert_id(){
return mysqli_insert_id($this->link_id);
}
public function affected_rows() {
return mysqli_affected_rows($this->link_id);
}
public function close(){
if($this->link_id!==null) $mysqli_close($this->link_id);
$this->link_id = null;
return true;
}
public function error(){
return mysqli_error($this->link_id);
}
}
?>
有点累了,设计模式常用的先学到这里,后续的以后再说,
愿法界众生,皆得安乐
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。