亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

PHP DB 數據庫連接類定義與用法示例

2024-05-05 00:07:20
字體:
來源:轉載
供稿:網友

本文實例講述了PHP DB 數據庫連接類定義與用法。分享給大家供大家參考,具體如下:

聲明:

近期觀看了一節 PHP 消息隊列視頻,對于講師WiconWang提供的代碼,在此分享一下,希望能對愛學習的小伙伴有所幫助…

<?php// 數據庫連接類class DB{ //私有的屬性 private static $dbcon=false; private $host; private $port; private $user; private $pass; private $db; private $charset; private $link; //私有的構造方法 private function __construct(){  $this->host = 'localhost';  $this->port = '3306';  $this->user = 'root';  $this->pass = 'root';  $this->db = 'imooc';  $this->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;  }  //獲得最后一條記錄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;  }  public function selectAll($table,$where,$fields='*',$order='',$skip=0,$limit=1000)  {       if(is_array($where)){          foreach ($where as $key => $val) {            if (is_numeric($val)) {              $condition = $key.'='.$val;            }else{              $condition = $key.'=/"'.$val.'/"';            }          }       } else {        $condition = $where;       }       if (!empty($order)) {         $order = " order by ".$order;       }       $sql = "select $fields from $table where $condition $order limit $skip,$limit";       $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,$limit=0){   //遍歷數組,得到每一個字段和字段的值   $str='';  foreach($data as $key=>$v){   $str.="$key='$v',";  }  $str=rtrim($str,',');   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;   }    if (!empty($limit)) {      $limit = " limit ".$limit;    }else{      $limit='';    }  //修改SQL語句  $sql="update $table set $str where $condition $limit";  $this->query($sql);  //返回受影響的行數  return mysqli_affected_rows($this->link);  }}?>

使用方法

  • 對DB類中__construct()中的配置信息,進行符合自己數據庫的修改
  • include 引入DB類
  • 使用DB類中的方法需要先進行實例化,以插入數據為例:
$db = DB::getIntance();$insert_data = ['order_id'=>'10010','order_amount' = '200.00','status'=> 1];$res = $db->insert('order_info',$insert_data);

希望本文所述對大家PHP程序設計有所幫助。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲激情在线| 亚洲综合国产精品| 亚洲第一区第一页| 日韩av在线免费播放| 国产精品久久久久久网站| 国产精品久久久| 欧美高跟鞋交xxxxxhd| 欧美激情欧美狂野欧美精品| 欧美日韩另类在线| 亚洲专区国产精品| 亚洲一二在线观看| 亚洲性线免费观看视频成熟| 精品欧美一区二区三区| 日韩免费av一区二区| 国产精品专区一| 亚洲情综合五月天| 亚洲人成人99网站| 国产成人精品在线观看| 亚洲黄色av女优在线观看| 久久九九精品99国产精品| 最近2019中文字幕一页二页| 中文字幕日韩在线观看| 福利一区福利二区微拍刺激| 亚洲一级免费视频| 性夜试看影院91社区| 欧美在线视频免费| 亚洲综合第一页| 国产精品一二三在线| 91最新在线免费观看| 色综合男人天堂| 亚洲综合最新在线| 亚洲精品日产aⅴ| 91久久精品日日躁夜夜躁国产| 国产精品爱久久久久久久| 91网站在线免费观看| 日韩少妇与小伙激情| 欧美日韩黄色大片| 成人一区二区电影| 日本中文字幕不卡免费| 欧美在线免费视频| 日韩欧美大尺度| 日韩欧美国产一区二区| 久久精品亚洲精品| 欧美激情图片区| 精品欧美aⅴ在线网站| 91影视免费在线观看| 全色精品综合影院| 国产丝袜一区二区三区免费视频| 91亚洲人电影| 亚洲欧美国内爽妇网| 国产91在线高潮白浆在线观看| 亚洲国产99精品国自产| 国产精品视频区1| 尤物九九久久国产精品的特点| 欧美精品免费在线| 日韩欧美国产黄色| 91精品久久久久久久久久久久久久| 米奇精品一区二区三区在线观看| 欧美成人小视频| 欧美国产亚洲精品久久久8v| 国产一区二区三区直播精品电影| 久久精品国产一区| 国产精品h在线观看| 色狠狠av一区二区三区香蕉蜜桃| www.久久撸.com| 久久99热精品这里久久精品| 亚洲精品永久免费| 亚洲最新av在线网站| 国产成人高清激情视频在线观看| 91久久久久久久一区二区| 成人国产精品久久久久久亚洲| 91沈先生在线观看| 亚洲天堂精品在线| 亚洲石原莉奈一区二区在线观看| 91成人免费观看网站| 日韩av不卡电影| 懂色aⅴ精品一区二区三区蜜月| 亚洲国产成人久久综合一区| 国产一区二区三区精品久久久| 国产精品久久久久久久久久尿| 国产日韩综合一区二区性色av| 92国产精品久久久久首页| 91精品国产高清自在线看超| 久久久久久久久久久免费精品| 亚洲第一视频网站| 亚洲欧美激情另类校园| 欧美福利视频在线观看| 日韩av在线免费播放| 欧美成人全部免费| 91在线观看免费观看| 国产精品99免视看9| 精品久久久香蕉免费精品视频| 国产成人aa精品一区在线播放| 91日本在线观看| 一区二区亚洲精品国产| 日韩69视频在线观看| 亚洲电影免费观看高清完整版在线| 在线国产精品播放| 亚洲国产另类 国产精品国产免费| 国产精品久久97| 日韩影视在线观看| 欧美性视频在线| 亚洲午夜久久久影院| 亚洲精品日韩激情在线电影| 日本中文字幕成人| 欧美精品在线第一页| 成人精品一区二区三区电影免费| 久久久在线视频| 91亚洲精品久久久久久久久久久久| 国产一区二区三区直播精品电影| 91亚洲国产成人精品性色| 久久久av免费| 91日韩在线视频| 亚洲美腿欧美激情另类| 欧美激情成人在线视频| 亚洲国产精久久久久久| 亚洲香蕉在线观看| 91亚洲va在线va天堂va国| 国产美女精品免费电影| 久久久久久久久久久久久久久久久久av| 38少妇精品导航| 欧美激情videos| 91久久久亚洲精品| 国产a∨精品一区二区三区不卡| 成人动漫网站在线观看| 成人h猎奇视频网站| 国产中文日韩欧美| 欧美亚洲在线视频| 亚洲成人1234| 中国人与牲禽动交精品| 在线视频日本亚洲性| 最新91在线视频| 欧美疯狂性受xxxxx另类| 亚洲人成网站免费播放| 亚洲国产成人精品久久久国产成人一区| 亚洲精品综合久久中文字幕| 亚洲精品不卡在线| 久久久久北条麻妃免费看| 国产91久久婷婷一区二区| 日韩成人在线视频观看| 韩日精品中文字幕| 国产精品mp4| 日韩一区av在线| 最新69国产成人精品视频免费| 欧美肥臀大乳一区二区免费视频| 欧美性高潮床叫视频| 久热国产精品视频| 久久亚洲精品一区| 国产精品免费网站| 欧美日韩第一视频| 国产精品老牛影院在线观看| 琪琪第一精品导航| 欧美第一页在线| 亚洲精品国产精品乱码不99按摩| 欧美日韩美女视频| 亚洲精品国产品国语在线| 久热精品视频在线观看| 中文字幕欧美专区| 国产在线观看精品| 国产精品一区二区3区| 日韩视频永久免费观看| 欧美精品在线免费观看| 懂色av中文一区二区三区天美| 国产精品成人va在线观看|