php基於PDO實現功能強大的MYSQL封裝類執行個體詳解

來源:互聯網
上載者:User
這篇文章主要介紹了php基於PDO實現功能強大的MYSQL封裝類,結合完整執行個體形式分析了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."<br /> The Error in ".$getLine." line <br /> This file dir on ".$getFile;  exit(); }}



以上就是本文的全部內容,希望對大家的學習有所協助。


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.