PHP 之模板模式

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

我们可能会遇到这种情况,为了实现一些业务逻辑,我们会对同一个对象来回重建进行业务处理


比如说做试卷,老师除了一套试卷,学生们拿到试卷只有两个地方不一样,填写的答案和名字


这样的话,整体的算法骨架是一定的,你只需要固定出来一套题就可以,子类去修改其中一两部


应用情境:数据库中间层的抽象类


上代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
<?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);
     }
}
?>



有点累了,设计模式常用的先学到这里,后续的以后再说,


愿法界众生,皆得安乐

本文转自 jackdongting 51CTO博客,原文链接:http://blog.51cto.com/10725691/1954849


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
JavaScript 前端开发 PHP
PHP - Laravel 视图模板(blade.php) @ 原始形态输出(Vue 与 PHP 混编)
PHP - Laravel 视图模板(blade.php) @ 原始形态输出(Vue 与 PHP 混编)
95 0
|
3月前
|
开发框架 前端开发 搜索推荐
分享97个框架模板PHP源码,总有一款适合你
分享97个框架模板PHP源码,总有一款适合你
29 2
|
8月前
|
PHP
PHP - Laravel Blade模板注释 {{-- 注释 --}} 与 <!-- 注释 --> 的区别
PHP - Laravel Blade模板注释 {{-- 注释 --}} 与 <!-- 注释 --> 的区别
62 0
|
8月前
|
PHP
PHP - Laravel 视图模板(blade.php) 模板继承(@extends、@yield、@section)
PHP - Laravel 视图模板(blade.php) 模板继承(@extends、@yield、@section)
132 0
|
8月前
|
PHP
PHP - Laravel 视图模板(blade.php) 模板引入与使用,及模板使用页面参数
PHP - Laravel 视图模板(blade.php) 模板引入与使用,及模板使用页面参数
131 0
|
8月前
|
PHP
PHP - Laravel 视图模板(blade.php) 循环便利
PHP - Laravel 视图模板(blade.php) 循环便利
87 0
|
8月前
|
PHP
PHP - Laravel 视图模板(blade.php) if 语句
PHP - Laravel 视图模板(blade.php) if 语句
56 0
|
8月前
|
PHP
PHP - Laravel 视图模板(blade.php)中使用函数
PHP - Laravel 视图模板(blade.php)中使用函数
95 0
|
8月前
|
JavaScript 前端开发 PHP
PHP - Laravel 视图模板(blade.php)导入JS、Css、素材文件并使用
PHP - Laravel 视图模板(blade.php)导入JS、Css、素材文件并使用
462 0
|
PHP
【技术分享】select下拉框option默认选中(php模板渲染)
【技术分享】select下拉框option默认选中(php模板渲染)
153 0