php封装的mysqli类完整实例

2025-05-29 0 80

本文实例讲述了php封装mysqli类。分享给大家供大家参考,具体如下:

类:

?

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

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212
<?php

header('content-type:text/html;charset=utf-8');

/*

掌握满足单例模式的必要条件

(1)私有的构造方法-为了防止在类外使用new关键字实例化对象

(2)私有的成员属性-为了防止在类外引入这个存放对象的属性

(3)私有的克隆方法-为了防止在类外通过clone成生另一个对象

(4)公有的静态方法-为了让用户进行实例化对象的操作

*/

class ConnectMysqli{

//私有的属性

private static $dbcon=false;

private $host;

private $port;

private $user;

private $pass;

private $db;

private $charset;

private $link;

//私有的构造方法

private function __construct($config=array()){

$this->host = $config['host'] ? $config['host'] : 'localhost';

$this->port = $config['port'] ? $config['port'] : '3306';

$this->user = $config['user'] ? $config['user'] : 'root';

$this->pass = $config['pass'] ? $config['pass'] : 'root';

$this->db = $config['db'] ? $config['db'] : 'small2';

$this->charset=isset($arr['charset']) ? $arr['charset'] : 'utf8';

//连接数据库

$this->db_connect();

//选择数据库

$this->db_usedb();

//设置字符集

$this->db_charset();

}

//连接数据库

private function db_connect(){

$this->link=mysqli_connect($this->host.':'.$this->port,$this->user,$this->pass);

if(!$this->link){

echo "数据库连接失败<br>";

echo "错误编码".mysqli_errno($this->link)."<br>";

echo "错误信息".mysqli_error($this->link)."<br>";

exit;

}

}

//设置字符集

private function db_charset(){

mysqli_query($this->link,"set names {$this->charset}");

}

//选择数据库

private function db_usedb(){

mysqli_query($this->link,"use {$this->db}");

}

//私有的克隆

private function __clone(){

die('clone is not allowed');

}

//公用的静态方法

public static function getIntance(){

if(self::$dbcon==false){

self::$dbcon=new self;

}

return self::$dbcon;

}

//执行sql语句的方法

public function query($sql){

$res=mysqli_query($this->link,$sql);

if(!$res){

echo "sql语句执行失败<br>";

echo "错误编码是".mysqli_errno($this->link)."<br>";

echo "错误信息是".mysqli_error($this->link)."<br>";

}

return $res;

}

//打印数据

public function p($arr){

echo "<pre>";

print_r($arr);

echo "</pre>";

}

public function v($arr){

echo "<pre>";

var_dump($arr);

echo "</pre>";

}

//获得最后一条记录id

public function getInsertid(){

return mysqli_insert_id($this->link);

}

/**

* 查询某个字段

* @param

* @return string or int

*/

public function getOne($sql){

$query=$this->query($sql);

return mysqli_free_result($query);

}

//获取一行记录,return array 一维数组

public function getRow($sql,$type="assoc"){

$query=$this->query($sql);

if(!in_array($type,array("assoc",'array',"row"))){

die("mysqli_query error");

}

$funcname="mysqli_fetch_".$type;

return $funcname($query);

}

//获取一条记录,前置条件通过资源获取一条记录

public function getFormSource($query,$type="assoc"){

if(!in_array($type,array("assoc","array","row")))

{

die("mysqli_query error");

}

$funcname="mysqli_fetch_".$type;

return $funcname($query);

}

//获取多条数据,二维数组

public function getAll($sql){

$query=$this->query($sql);

$list=array();

while ($r=$this->getFormSource($query)) {

$list[]=$r;

}

return $list;

}

/**

* 定义添加数据的方法

* @param string $table 表名

* @param string orarray $data [数据]

* @return int 最新添加的id

*/

public function insert($table,$data){

//遍历数组,得到每一个字段和字段的值

$key_str='';

$v_str='';

foreach($data as $key=>$v){

if(empty($v)){

die("error");

}

//$key的值是每一个字段s一个字段所对应的值

$key_str.=$key.',';

$v_str.="'$v',";

}

$key_str=trim($key_str,',');

$v_str=trim($v_str,',');

//判断数据是否为空

$sql="insert into $table ($key_str) values ($v_str)";

$this->query($sql);

//返回上一次增加操做产生ID值

return $this->getInsertid();

}

/*

* 删除一条数据方法

* @param1 $table, $where=array('id'=>'1') 表名 条件

* @return 受影响的行数

*/

public function deleteOne($table, $where){

if(is_array($where)){

foreach ($where as $key => $val) {

$condition = $key.'='.$val;

}

} else {

$condition = $where;

}

$sql = "delete from $table where $condition";

$this->query($sql);

//返回受影响的行数

return mysqli_affected_rows($this->link);

}

/*

* 删除多条数据方法

* @param1 $table, $where 表名 条件

* @return 受影响的行数

*/

public function deleteAll($table, $where){

if(is_array($where)){

foreach ($where as $key => $val) {

if(is_array($val)){

$condition = $key.' in ('.implode(',', $val) .')';

} else {

$condition = $key. '=' .$val;

}

}

} else {

$condition = $where;

}

$sql = "delete from $table where $condition";

$this->query($sql);

//返回受影响的行数

return mysqli_affected_rows($this->link);

}

/**

* [修改操作description]

* @param [type] $table [表名]

* @param [type] $data [数据]

* @param [type] $where [条件]

* @return [type]

*/

public function update($table,$data,$where){

//遍历数组,得到每一个字段和字段的值

$str='';

foreach($data as $key=>$v){

$str.="$key='$v',";

}

$str=rtrim($str,',');

//修改SQL语句

$sql="update $table set $str where $where";

$this->query($sql);

//返回受影响的行数

return mysqli_affected_rows($this->link);

}

}

?>

用法测试:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18
//mysqli测试

$db=ConnectMysqli::getIntance();

//var_dump($db);

/*$sql="select * from acticle";

$list=$db->getAll($sql);

$db->p($list);*/

/*$sql="select * from acticle where acticle_id=95";

$list=$db->getRow($sql);

$db->p($list);

*/

/*$sql="select title from acticle";

$list=$db->getOne($sql);

$db->p($list);不行*/

//$list=$db->insert("users",$_POST);

//$del=$db->deleteOne("users","id=29");

//$del=$db->deleteAll("users","id in(27,28)");

//$up=$db->update("users",$_POST,"id=27");

//print_R($list);

希望本文所述对大家PHP程序设计有所帮助。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 php封装的mysqli类完整实例 https://www.kuaiidc.com/95746.html

相关文章

发表评论
暂无评论