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

首頁 > 語言 > PHP > 正文

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

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

本文實例講述了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电影| 高清欧美性猛交| 色一区av在线| 国产精品视频公开费视频| 久久中文久久字幕| 欧美大肥婆大肥bbbbb| 精品国产一区二区在线| 国产福利视频一区| 国产脚交av在线一区二区| 97超碰蝌蚪网人人做人人爽| 亚洲激情在线视频| 高清一区二区三区四区五区| 欧美日韩国产黄| 国产精品视频区| 久久精品这里热有精品| 成人欧美一区二区三区黑人| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美激情精品久久久| 国产成人精品在线| 91av在线影院| 久久综合五月天| 日韩美女视频中文字幕| 中文字幕亚洲一区二区三区| 日韩美女在线播放| 亚洲xxx大片| 91精品国产自产在线| 欧美国产日韩二区| 国内精品久久久久影院 日本资源| 亚洲国产精品推荐| 国外成人性视频| 亚洲理论在线a中文字幕| 日韩中文字幕免费| 怡红院精品视频| 亚洲性生活视频在线观看| 亚洲免费电影在线观看| 国产精品久久久久久久7电影| 亚洲国产精品专区久久| 亚洲成色777777女色窝| 国产在线精品成人一区二区三区| 成人伊人精品色xxxx视频| 日韩一二三在线视频播| 国产精品第3页| 中文字幕日韩精品在线| 揄拍成人国产精品视频| 国产日韩亚洲欧美| 欧美裸体xxxx极品少妇| 81精品国产乱码久久久久久| 精品成人av一区| 欧亚精品在线观看| 国产一区二区成人| 久久69精品久久久久久久电影好| 亚洲国产精品成人av| 91精品国产777在线观看| 久久99久久久久久久噜噜| 欧美高清在线播放| 宅男66日本亚洲欧美视频| 欧美日韩人人澡狠狠躁视频| 久久男人的天堂| 亚洲精品美女久久| 精品成人乱色一区二区| 日韩免费av片在线观看| 久久精品中文字幕免费mv| 亚洲精品视频在线观看视频| 中文字幕国产亚洲2019| 亚洲精品自在久久| 成人欧美一区二区三区在线湿哒哒| 国产精品成av人在线视午夜片| 久久免费福利视频| 91午夜理伦私人影院| 欧美国产亚洲视频| 性色av一区二区咪爱| 亚洲国产高清高潮精品美女| www.欧美三级电影.com| 性色av一区二区三区红粉影视| 亚洲黄色片网站| 亚洲成av人片在线观看香蕉| 国产精品国产三级国产aⅴ浪潮| 国产成人免费av| 日韩中文字幕在线看| 色婷婷av一区二区三区在线观看| 日韩网站免费观看高清| 欧美日韩在线观看视频小说| 久久久久在线观看| 蜜臀久久99精品久久久无需会员| 九九热精品视频在线播放| 日韩电影免费观看中文字幕| 欧美视频在线看| 欧美日本精品在线| 亚洲欧洲国产精品| 国产亚洲一区二区在线| 97av在线视频| 国产在线精品自拍| 91夜夜未满十八勿入爽爽影院| 久久精品国产免费观看| 欧美性色xo影院| www.欧美三级电影.com| 国产欧美欧洲在线观看| 黑人巨大精品欧美一区二区三区| 中文字幕久热精品视频在线| 欧洲一区二区视频| 欧美日韩成人在线播放| 亚洲视频免费一区| 色悠悠国产精品| 亚洲国产精品电影| 欧美午夜性色大片在线观看| 亚洲成人av在线| 欧美精品免费在线| 国内精品400部情侣激情| 欧美日韩一区二区三区| 国产精品久久久久久网站| 美女性感视频久久久| 久久精品国产亚洲精品| 在线播放精品一区二区三区| 国产91精品久久久久久久| 91成人天堂久久成人| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲日韩中文字幕| 国产精品第一区| 欧美性生活大片免费观看网址| 亚洲无线码在线一区观看| 亚洲精品成人久久电影| 亚洲女人天堂色在线7777| 精品视频久久久久久久| 欧美国产第二页| 精品中文字幕在线观看| 久久久99久久精品女同性| 一本久久综合亚洲鲁鲁| 国产97在线播放| 日韩精品欧美激情| 日本免费久久高清视频| 精品国产成人在线| 最近2019中文字幕mv免费看| 亚洲aⅴ日韩av电影在线观看| 国产主播在线一区| 韩国精品久久久999| 在线精品高清中文字幕| 91精品国产乱码久久久久久蜜臀| 日韩av在线网址| 亚洲国产精品久久久久秋霞蜜臀| 欧美国产精品va在线观看| 在线日韩av观看| 亚洲激情在线观看视频免费| 久久中文字幕一区| 亚洲欧洲在线看| 欧美激情精品久久久久久久变态| 热久久美女精品天天吊色| 欧美精品免费看| 青青久久aⅴ北条麻妃| 国产欧美一区二区三区四区| 精品国产91久久久久久| 亚洲在线免费看| 成人福利网站在线观看11| 国产美女久久久| 俺也去精品视频在线观看| 97超碰国产精品女人人人爽| 8x拔播拔播x8国产精品| 亚洲一区二区日本|