php实现mysql封装类示例
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php实现mysql封装类示例相关的知识,希望对你有一定的参考价值。
参考技术A php封装mysql类复制代码
代码如下:
<?php
class
Mysql
private
$host;
private
$user;
private
$pwd;
private
$dbName;
private
$charset;
private
$conn
=
null;
public
function
__construct()
$this->host
=
'localhost';
$this->user
=
'root';
$this->pwd
=
'root';
$this->dbName
=
'test';
$this->connect($this->host,$this->user,$this->pwd);
$this->switchDb($this->dbName);
$this->setChar($this->charset);
//负责链接
private
function
connect($h,$u,$p)
$conn
=
mysql_connect($h,$u,$p);
$this->conn
=
$conn;
//负责切换数据库
public
function
switchDb($db)
$sql
=
'use'
.
$db;
$this->query($sql);
//负责设置字符集
public
function
setChar($char)
$sql
=
'set
names'
.
$char;
$this->query($sql);
//负责发送sql查询
public
function
query($sql)
return
mysql_query($sql,$this->conn);
//负责获取多行多列的select结果
public
function
getAll($sql)
$list
=
array();
$rs
=
$this->query($sql);
if
(!$rs)
return
false;
while
($row
=
mysql_fetch_assoc($rs))
$list[]
=
$row;
return
$list;
public
function
getRow($sql)
$rs
=
$this->query($sql);
if(!$rs)
return
false;
return
mysql_fetch_assoc($rs);
public
function
getOne($sql)
$rs
=
$this->query($sql);
if
(!$rs)
return
false;
return
mysql_fetch_assoc($rs);
return
$row[0];
public
function
close()
mysql_close($this->conn);
echo
'<pre>';
$mysql
=
new
Mysql();
print_r($mysql);
$sql
=
"insert
into
stu
values
(4,'wangwu','99998')";
if($mysql->query($sql))
echo
"query成功";
else
echo
"失败";
echo
"<br
/>";
$sql
=
"select
*
from
stu";
$arr
=
$mysql->getAll($sql);
print_r($arr);
?>
PHP常用封装类
1、mysql.class.php
<?php // namespace Package; /** * MySQL 类 * @author cxm <tsai.er6@gmail.com> * */ class MySQL { private static $link = null; //数据库连接 /** * 私有的构造方法 */ private function __construct() {} /** * 连接数据库 * @return obj 资源对象 */ private static function conn() { if (self::$link === null) { $cfg = require \'./config.php\'; self::$link = new mysqli($cfg[\'host\'], $cfg[\'user\'], $cfg[\'pwd\'], $cfg[\'db\']); //设置字符集 self::query("set names ".$cfg[\'charset\']); } return self::$link; } /** * 执行一条sql语句 * @param str $sql 查询语句 * @return obj 结果集对象 */ public static function query($sql) { return self::conn()->query($sql); } /** * 获取多行数据 * @para str $sql 查询语句 * @return arr 多行数据 */ public static function getAll($sql) { $data = array(); $res = self::query($sql); while (($row = $res->fetch_assoc()) != FALSE) { $data[] = $row; } return $data; } /** * 获取一行数据 * @param str $row 查询语句 * @return arr 单行数据 */ public static function getRow($sql) { $res = self::query($sql); return $res->fetch_assoc(); } /** * 获取单个结果 * @param str $sql 查询语句 * @return str 单个结果 */ public static function getOne($sql) { $res = self::query($sql); $data = $res->fetch_row(); return $data[0]; } /** * 插入/更新数据 * @param str $table 表明 * @param arr $data 插入/更新的数据 * @param str $act insert/update * @param str $where 更新条件 * @return bool //插入/更新是否成功 */ public static function exec($table, $data, $act = \'insert\', $where = \'0\') { // 插入操作 if ($act == \'insert\') { $sql = \'insert into \'.$table; $sql .= \'(\'.implode(\',\', array_keys($data)).\')\'; $sql .= " values (\'".implode("\',\'", array_values($data))."\')"; } else if ($act == \'update\') { $sql = \'update \'.$table . \'set \'; foreach ($data as $k => $v) { $sql .= $k.\'=\'."\'$v\',"; } $sql = rtrim($sql, \',\'); $sql .= \' where 1 and \'.$where; } return self::query($sql); } /** * 获取最近一次插入的主键值 * @return int 主键 */ public static function getLastId() { return self::conn()->insert_id; } /** * 获取最近一次操作影响的行数 * @return int 影响的行数 */ public static function getAffectedRows() { return self::conn()->affected_rows(); } /** * 关闭数据库连接 * @return bool 是否关闭 */ public static function close() { return self::conn()->close(); } } ?>
2.page.class.php
<?php // namespace Package; /** * 分页类 * @author cxm <tsai.er6@gmail.com> * */ class Page { private $num; //总的文章数 private $cnt; //每页显示的文章数 private $curr; //当前的页码数 private $p = \'page\'; //分页参数名 private $pageCnt = 5; //分栏总共显示的页数 private $firstRow; //每页的第一行数据 private $pageIndex = array(); //分页信息 /** * 构造函数 * @param int $num 总的文章数 * @param int $cnt 每页显示的文章数 */ public function __construct($num, $cnt = 10) { $this->num = $num; $this->cnt = $cnt; $this->curr = empty($_GET[$this->p]) ? 1 : intval($_GET[$this->p]); $this->curr = $this->curr > 0 ? $this->curr : 1; $this->firstRow = $this->cnt * ($this->curr - 1); $this->getPage(); } /** * 分页方法 */ private function getPage() { $page = ceil($this->num / $this->cnt); //总的页数 $left = max(1, $this->curr - floor($this->pageCnt/2)); //计算最左边页码 $right = min($left + $this->pageCnt - 1, $page); //计算最右边页码 $left = max(1, $right - ($this->pageCnt - 1)); //当前页码往右靠,需要重新计算左边页面的值 for ($i = $left; $i <= $right; $i++) { if ($i == 1) { $index = \'第1页\'; } else if ($i == $page) { $index = \'最后一页\'; } else { $index = \'第\'.$i.\'页\'; } $_GET[\'page\'] = $i; $this->pageIndex[$index] = http_build_query($_GET); } } /** * 返回分页信息数据 * @return [type] [description] */ public function show() { return $this->pageIndex; } } ?>
3.thumb.class.php
<?php /** * 缩略图类 * @author cxm <tsai.er6@gmail.com> * */ class Thumb { private $thumbWidth; //缩略图的宽 private $thumbHeight; //缩略图的高 private $thumbPath; //缩略图保存的路径 private $sourcePath; //原图的路径 private $sourceWidth; //原图的宽度 private $sourceHeight; //原图的高度 private $sourceType; //原图的图片类型 /** * 构造函数 * @param str $sourcePath 原图的绝对路径 * @param integer $thumbWidth 缩略图的宽 * @param integer $thumbHeight 缩略图的高 */ public function __construct($sourcePath, $thumbWidth = 200, $thumbHeight = 200) { // 获取原图的绝对路径 $this->sourcePath = $sourcePath; // 获取缩略图的大小 $this->thumbWidth = $thumbWidth; $this->thumbHeight = $thumbHeight; $this->thumbPath = $this->getThumbPath(); // 计算大图的大小 list($this->sourceWidth, $this->sourceHeight, $this->sourceType) = getimagesize($this->sourcePath); } /** * 确定缩略图保存的路径 * @return [type] [description] */ private function getThumbPath() { $ext = $this->getExt(); $filename = basename($this->sourcePath,\'.\'.$ext).\'_thumb\'.\'.\'.$ext; return $thumbPath = __DIR__.\'/\'.$filename; } /** * 获取原图的扩展名 * @return str 扩展名 */ private function getExt() { return pathinfo($this->sourcePath, PATHINFO_EXTENSION); } /** * 检测原图的扩展名是否合法,并返回相应类型 * @return bool/str 原图的类型 */ public function getType() { $typeArr = array( 1 => \'gif\', 2 => \'jpeg\', 3 => \'png\', 15 => \'wbmp\' ); if (!in_array($this->sourceType, array_keys($typeArr))) { return false; } return $typeArr[$this->sourceType]; } /** * 按照缩略图大小,计算大图的缩放比例 * @return float 缩放比例 */ public function calculateRate() { return min($this->thumbWidth / $this->sourceWidth, $this->thumbHeight / $this->sourceHeight); } /** * 计算大图按照缩放比例后,最终的图像大小 * @param float $rate 缩放比例 * @return arr 缩放后的图片大小 */ public function getImageSizeRate($rate) { $width = $this->sourceWidth * $rate; $height = $this->sourceHeight * $rate; return array(\'w\' => $width, \'h\' => $height); } /** * 保存成文件 * @return [type][description] */ public function saveFile($image) { $method = "image".$this->getType(); $method($image, $this->thumbPath); } /** * 进行绘画操作 * @return [type] [description] */ public function draw() { if (!($type = $this->getType())) { echo "文件类型不支持"; return; } // 创建大图和小图的画布 $method = "imagecreatefrom".$type; $bigCanvas = $method($this->sourcePath); $smallCanvas = imagecreatetruecolor($this->thumbWidth, $this->thumbHeight); // 创建白色画笔,并给小图画布填充背景 $white = imagecolorallocate($smallCanvas, 255, 255, 255); imagefill($smallCanvas, 0, 0, $white); // 计算大图的缩放比例 $rate = $this->calculateRate(); // 计算大图缩放后的大小信息 $info = $this->getImageSizeRate($rate); // 进行缩放 imagecopyresampled($smallCanvas, $bigCanvas, ($this->thumbWidth - $info[\'w\'])/2, ($this->thumbHeight - $info[\'h\'])/2, 0, 0, $info[\'w\'], $info[\'h\'], $this->sourceWidth, $this->sourceHeight); // 保存成文件 $this->saveFile($smallCanvas); // 销毁画布 imagedestroy($bigCanvas); imagedestroy($smallCanvas); } } ?>
4.upload.class.php
<meta charset="utf8"/> <?php /** * 文件上传类 * @author cxm <tsai.er6@gmail.com> */ class Upload { private $allowExt = array(\'gif\',\'jpg\',\'jpeg\',\'bmp\',\'png\',\'swf\'); //显示文件上传的后缀名 private $maxSize = 1; //限制最大文件上传1M /** * 获取文件的信息 * @param str $flag 上传文件的标识 * @return arr 上传文件的信息数组 */ public function getInfo($flag) { return $_FILES[$flag]; } /** * 获取文件的扩展名 * @param str $filename 文件名 * @return str 文件扩展名 */ public function getExt($filename) { return pathinfo($filename, PATHINFO_EXTENSION); } /** * 检测文件扩展名是否合法 * @param str $filename 文件名 * @return bool 文件扩展名是否合法 */ private function checkExt($filename) { $ext = $this->getExt($filename); return in_array($ext, $this->allowExt); } /** * 检测文件大小是否超过限制 * @param int size 文件大小 * @return bool 文件大小是否超过限制 */ public function checkSize($size) { return $size < $this->maxSize*1024*1024; } /** * 随机的文件名 * @param int $len 随机文件名的长度 * @return str 随机字符串 */ public function randName($len = 6) { return substr(str_shuffle(\'abcdefghijklmnopqrstuvwxyzABCDEFGHIJLMKOPQRSTUVWXYZ0123456789\'),0,$len); } /** * 创建文件上传到的路径 * @return str 文件上传的路径 */ public function createDir() { $dir = \'./upload/\'.date(\'Y/m/d\',time()); if (is_dir($dir) || mkdir($dir, 0777, true)) { return $dir; } } /** * 文件上传 * @param str $flag 文件上传标识 * @return arr 文件上传信息 */ public function uploadFile($flag) { if ($_FILES[$flag][\'name\'] === \'\' || $_FILES[$flag][\'error\'] !== 0) { echo "没有上传文件"; return; } $info = $this->getInfo($flag); if (!$this->checkExt($info[\'name\'])) { echo "不支持的文件类型"; return; } if (!$this->checkSize($info[\'size\'])) { echo "文件大小超过限制"; return; } $filename = $this->randName().\'.\'.$this->getExt($info[\'name\']); $dir = $this->createDir(); if (!move_uploaded_file($info[\'tmp_name\'], $dir.\'/\'.$filename)) { echo "文件上传失败"; } else { return array(\'filename\' => $filename, \'dir\' => $dir); } } } ?>
以上是关于php实现mysql封装类示例的主要内容,如果未能解决你的问题,请参考以下文章