PHP基於ORM方式操作MySQL資料庫的方法

來源:互聯網
上載者:User
這篇文章主要介紹了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最全快速鍵總結

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.