我们可能会遇到这种情况,为了实现一些业务逻辑,我们会对同一个对象来回重建进行业务处理
比如说做试卷,老师除了一套试卷,学生们拿到试卷只有两个地方不一样,填写的答案和名字
这样的话,整体的算法骨架是一定的,你只需要固定出来一套题就可以,子类去修改其中一两部
应用情境:数据库中间层的抽象类
上代码
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