侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

php基于PDO实现功能强大的MYSQL封装类实例

php  /  管理员 发布于 7年前   209

本文实例讲述了php基于PDO实现功能强大的MYSQL封装类。分享给大家供大家参考,具体如下:

class CPdo{ protected $_dsn = "mysql:host=localhost;dbname=test"; protected $_name = "root"; protected $_pass = ""; protected $_condition = array(); protected $pdo; protected $fetchAll; protected $query; protected $result; protected $num; protected $mode; protected $prepare; protected $row; protected $fetchAction; protected $beginTransaction; protected $rollback; protected $commit; protected $char; private static $get_mode; private static $get_fetch_action; /** *pdo construct */ public function __construct($pconnect = false) {  $this->_condition = array(PDO::ATTR_PERSISTENT => $pconnect);  $this->pdo_connect(); } /** *pdo connect */ private function pdo_connect() {  try{   $this->pdo = new PDO($this->_dsn,$this->_name,$this->_pass,$this->_condition);  }  catch(Exception $e) {   return $this->setExceptionError($e->getMessage(), $e->getline, $e->getFile);  } } /** *self sql get value action */ public function getValueBySelfCreateSql($sql, $fetchAction = "assoc",$mode = null) {  $this->fetchAction = $this->fetchAction($fetchAction);  $this->result = $this->setAttribute($sql, $this->fetchAction, $mode);  $this->AllValue = $this->result->fetchAll();  return $this->AllValue; } /** *select condition can query */ private function setAttribute($sql, $fetchAction, $mode) {  $this->mode = self::getMode($mode);  $this->fetchAction = self::fetchAction($fetchAction);  $this->pdo->setAttribute(PDO::ATTR_CASE, $this->mode);  $this->query = $this->base_query($sql);  $this->query->setFetchMode($this->fetchAction);  return $this->query; } /** *get mode action */ private static function getMode($get_style){  switch($get_style) {   case null:    self::$get_mode = PDO::CASE_NATURAL;   break;   case true:    self::$get_mode = PDO::CASE_UPPER;   break;   case false;   self::$get_mode= PDO::CASE_LOWER;   break;  }  return self::$get_mode; } /** *fetch value action */ private static function fetchAction($fetchAction) {  switch($fetchAction) {   case "assoc":    self::$get_fetch_action = PDO::FETCH_ASSOC; //asso array   break;   case "num":    self::$get_fetch_action = PDO::FETCH_NUM; //num array   break;   case "object":    self::$get_fetch_action = PDO::FETCH_OBJ; //object array   break;   case "both":    self::$get_fetch_action = PDO::FETCH_BOTH; //assoc array and num array   break;   default:    self::$get_fetch_action = PDO::FETCH_ASSOC;   break;  }  return self::$get_fetch_action; } /** *get total num action */ public function rowCount($sql) {  $this->result = $this->base_query($sql);  $this->num = $this->result->rowCount();  return $this->num; } /* *simple query and easy query action */ public function query($table, $column = "*",$condition = array(), $group = "",$order = "", $having = "", $startSet = "",$endSet = "",$fetchAction = "assoc",$params = null){  $sql = "select ".$column." from `".$table."` ";  if ($condition != null) {   foreach($condition as $key=>$value) {    $where .= "$key = '$value' and ";   }   $sql .= "where $where";   $sql .= "1 = 1 ";  }  if ($group != "") {   $sql .= "group by ".$group." ";  }  if ($order != "") {   $sql .= " order by ".$order." ";  }  if ($having != "") {   $sql .= "having '$having' ";  }  if ($startSet != "" && $endSet != "" && is_numeric($endSet) && is_numeric($startSet)) {   $sql .= "limit $startSet,$endSet";  }  $this->result = $this->getValueBySelfCreateSql($sql, $fetchAction, $params);  return $this->result; } /** *execute delete update insert and so on action */ public function exec($sql) {  $this->result = $this->pdo->exec($sql);  $substr = substr($sql, 0 ,6);  if ($this->result) {   return $this->successful($substr);  } else {   return $this->fail($substr);  } } /** *prepare action */ public function prepare($sql) {  $this->prepare = $this->pdo->prepare($sql);  $this->setChars();  $this->prepare->execute();  while($this->rowz = $this->prepare->fetch()) {   return $this->row;  } } /** *USE transaction */ public function transaction($sql) {  $this->begin();  $this->result = $this->pdo->exec($sql);  if ($this->result) {   $this->commit();  } else {   $this->rollback();  } } /** *start transaction */ private function begin() {  $this->beginTransaction = $this->pdo->beginTransaction();  return $this->beginTransaction; } /** *commit transaction */ private function commit() {  $this->commit = $this->pdo->commit();  return $this->commit; } /** *rollback transaction */ private function rollback() {  $this->rollback = $this->pdo->rollback();  return $this->rollback; } /** *base query */ private function base_query($sql) {  $this->setChars();  $this->query = $this->pdo->query($sql);  return $this->query; } /** *set chars */ private function setChars() {  $this->char = $this->pdo->query("SET NAMES 'UTF8'");  return $this->char; } /** *process sucessful action  */ private function successful($params){  return "The ".$params." action is successful"; } /** *process fail action */ private function fail($params){  return "The ".$params." action is fail"; } /** *process exception action */ private function setExceptionError($getMessage, $getLine ,$getFile) {  echo "Error message is ".$getMessage."
The Error in ".$getLine." line
This file dir on ".$getFile; exit(); }}

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP基于pdo操作数据库技巧总结》、《php+Oracle数据库程序设计技巧总结》、《PHP+MongoDB数据库操作技巧大全》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

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

您可能感兴趣的文章:

  • 防止MySQL注入或HTML表单滥用的PHP程序
  • PHP MYSQL注入攻击需要预防7个要点
  • PHP+mysql防止SQL注入的方法小结
  • php mysql_real_escape_string addslashes及mysql绑定参数防SQL注入攻击
  • Php中用PDO查询Mysql来避免SQL注入风险的方法
  • PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】
  • php中mysql连接方式PDO使用详解
  • php中数据库连接方式pdo和mysqli对比分析
  • PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】
  • PHP使用PDO创建MySQL数据库、表及插入多条数据操作示例
  • php使用mysqli和pdo扩展,测试对比mysql数据库的执行效率完整示例
  • PHP使用PDO实现mysql防注入功能详解


  • 上一条:
    PHP批量修改文件名称的方法分析
    下一条:
    php实现通过soap调用.Net的WebService asmx文件
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客