這篇文章主要介紹了PHP基於ORM方式操作MySQL資料庫,結合具體執行個體形式分析了php針對mysql資料庫常用操作的封裝與提示,需要的朋友可以參考下
具體如下:
ORM----Oriented Relationship Mapper,即用物件導向的方式來操作資料庫。歸根結底,還是對於SQL語句的封裝。
首先,我們的資料庫有如下一張表:
我們希望能夠對這張表,利用setUserid("11111"),即可以設定userid;getUserid()既可以獲得對象的userid。所以,我們需要建立model對象,與資料庫中的表對應。
由於每張表所對應的model都應該是有set/get操作,所以,我們用一個父類BasicModel進行定義。其他model都是繼承至這個model。
BasicModel的代碼如下:
<?php /* * author:Tammy Pi * function:Model類的基類,封裝set/get操作 */ class BasicModel{ private $map = null; function TbUser() { $this->map = array(); } function __set($key,$value){ $this->map[$key] = $value; } function __get($key){ return $this->map[$key]; } function __call($name,$arguments) { if(substr($name,0,3)=='set'){ $this->__set(strtolower(substr($name,3)),$arguments[0]); }else{ return $this->__get(strtolower(substr($name,3))); } } }?>
那麼,與tb_user表相互對應的model類TbUser則對它進行繼承。
<?php require_once("BasicModel.php"); class TbUser extends BasicModel{ }?>
這樣,我們就可以對TbUser的執行個體進行set/get操作了。
要用ORM進行操作資料庫,就必須可以findByWhere($where)進行查詢,返回的為對象數組;save($tbUser)進行儲存;delete($obj)進行刪除;update($obj)進行更新操作。
本質上,就是使用者傳入的是對象,我們再利用代碼將對象轉換為SQL語句。本質上,執行的還是SQL語句。
所以,我們對一系列的操作用介面表示。IBasicDAO的代碼如下:
<?php interface IBasicDAO { public function findByWhere($where); public function findWhereOrderBy($where,$order,$start=null,$limit=null); public function save($obj); public function delete($obj); public function update($obj); }?>
我們最關鍵,就是對此介面進行實現。完成對象和SQL的轉換。
BasicDAO的代碼如下:
<?php require_once("IBasicDAO.php"); class BasicDAO implements IBasicDAO{ protected $modelName = null; private $tableName = null; private $h = "localhost"; private $user = "root"; private $pass = "root"; private $db = "db_toilet"; //獲得串連 public function getConnection(){ $conn = mysqli_connect($this->h,$this->user,$this->pass,$this->db); return $conn; } //初始化 public function init() { //根據model的名字得到表的名字 $this->tableName = strtolower(substr($this->modelName,0,2))."_".strtolower(substr($this->modelName,2)); } //獲得一個表的列名 public function getColumn($tableName) { $sql = "show columns from ".$tableName; $conn = $this->getConnection(); $columns = array(); if($conn!=null){ $rtn = mysqli_query($conn,$sql); while($rtn!==false&&($row=mysqli_fetch_array($rtn))!=null){ $columns[] = $row[0]; } mysqli_close($conn); } return $columns; } //條件查詢 public function findByWhere($where){ //獲得資料表的列名 $columns = $this->getColumn($this->tableName); //拼接sql語句 $sql = "select * from ".$this->tableName." where ".$where; $conn = $this->getConnection(); $arr = array(); if($conn!=null){ $rtn = mysqli_query($conn,$sql); while($rtn!==false&&($row=mysqli_fetch_array($rtn))!=null){ $index = -1; $obj = new $this->modelName(); foreach($columns as $column){ $obj->{"set".ucfirst($column)}($row[++$index]); } $arr[] = $obj; } mysqli_close($conn); } return $arr; } //分頁查詢;支援排序 public function findWhereOrderBy($where,$order,$start=null,$limit=null){ //獲得資料表的列名 $columns = $this->getColumn($this->tableName); //拼接sql語句 $sql = "select * from ".$this->tableName." where ".$where." order by ".$order; if($start!=null&&$limit!=null){ $sql .= "limit ".$start.",".$limit; } $conn = $this->getConnection(); $arr = array(); if($conn!=null){ $rtn = mysqli_query($conn,$sql); while($rtn!==false&&($row=mysqli_fetch_array($rtn))!=null){ $index = -1; $obj = new $this->modelName(); foreach($columns as $column){ $obj->{"set".ucfirst($column)}($row[++$index]); } $arr[] = $obj; } mysqli_close($conn); } return $arr; } //儲存操作 public function save($obj){ $columns = $this->getColumn($this->tableName); $conn = $this->getConnection(); $tag = false; if($conn!=null){ $sql = "insert into ".$this->tableName."("; foreach($columns as $column){ $sql .= $column.","; } $sql = substr($sql,0,strlen($sql)-1).") values("; foreach($columns as $column){ $value = $obj->{"get".ucfirst($column)}(); //判斷$value的類型 if($value==null){ $sql .= "null,"; }else if(preg_match("/^[0-9]*$/", $value)){ //是數字 $sql .= $value.","; }else{ $sql .= "'".$value."',"; } } $sql = substr($sql,0,strlen($sql)-1); $sql .= ")"; //執行sql語句 mysqli_query($conn,$sql); $tag = true; mysqli_close($conn); } return $tag; } //刪除操作 public function delete($obj){ $conn = $this->getConnection(); $tag = false; if($conn!=null){ $sql = "delete from ".$this->tableName." where "; $columns = $this->getColumn($this->tableName); $value = $obj->{"get".ucfirst($columns[0])}(); if($value!=null){ //是數字 if(preg_match("/^[0-9]*$/", $value)){ $sql .= $columns[0]."=".$value; }else{ $sql .= $columns[0]."='".$value."'"; } //執行 mysqli_query($conn,$sql); $tag = true; } mysqli_close($conn); } return $tag; } //更新操作 public function update($obj){ $conn = $this->getConnection(); $columns = $this->getColumn($this->tableName); $tag = false; if($conn!=null){ $sql = "update ".$this->tableName." set "; for($i=1;$i<count($columns);$i++){ $column = $columns[$i]; $value = $obj->{"get".ucfirst($columns[$i])}(); if($value==null){ $sql .= $column."=null,"; }else if(preg_match("/^[0-9]*$/",$value)){ $sql .= $column."=".$value.","; }else{ $sql .= $column."='".$value."',"; } } $sql = substr($sql,0,strlen($sql)-1); $sql .= " where "; $tempColumn = $columns[0]; $tempValue = $obj->{"get".ucfirst($columns[0])}(); if(preg_match("/^[0-9]*$/", $tempValue)){ $sql .= $tempColumn."=".$tempValue; }else{ $sql .= $tempColumn."='".$tempValue."'"; } //執行操作 mysqli_query($conn,$sql); $tag = true; mysqli_close($conn); } return $tag; } }?>
那麼,對tb_user表進行操作時,主要利用的是TbUserDAO,它將modelName設定為"TbUser",代碼就得知操作的表為tb_user,然後就可以進行一系列操作了。
<?php require_once("BasicDAO.php"); require_once("../model/TbUser.php"); class TbUserDAO extends BasicDAO{ function TbUserDAO(){ $this->modelName = 'TbUser'; parent::init(); } }?>
那麼,就可以採用物件導向的方式對資料庫進行操作了。
如:
$tbUserDAO = new TbUserDAO();$tbUser = new TbUser();$tbUser->setUserid("fetchingsoft@163.com");$tbUser->setUsername("fetching");$tbUserDAO->update($tbUser);echo "執行成功!";print_r($list);
這樣對資料庫中的記錄進行更新。
相關推薦:
實現form自動認可的方法詳解
phpstorm中如何使用正則匹配刪除空行、注釋行
PHPstorm最全快速鍵總結