PHP基于ORM方式操作MySQL數(shù)據(jù)庫實例
本文實例講述了PHP基于ORM方式操作MySQL數(shù)據(jù)庫。分享給大家供大家參考,具體如下:
ORM----Oriented Relationship Mapper,即用面向?qū)ο蟮姆绞絹聿僮鲾?shù)據(jù)庫。歸根結(jié)底,還是對于SQL語句的封裝。
首先,我們的數(shù)據(jù)庫有如下一張表:
我們希望能夠?qū)@張表,利用setUserid("11111"),即可以設(shè)置userid;getUserid()既可以獲得對象的userid。所以,我們需要建立model對象,與數(shù)據(jù)庫中的表對應(yīng)。
由于每張表所對應(yīng)的model都應(yīng)該是有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表相互對應(yīng)的model類TbUser則對它進行繼承。
<?php require_once("BasicModel.php"); class TbUser extends BasicModel{ } ?>
這樣,我們就可以對TbUser的實例進行set/get操作了。
要用ORM進行操作數(shù)據(jù)庫,就必須可以findByWhere($where)進行查詢,返回的為對象數(shù)組;save($tbUser)進行保存;delete($obj)進行刪除;update($obj)進行更新操作。
本質(zhì)上,就是用戶傳入的是對象,我們再利用代碼將對象轉(zhuǎn)換為SQL語句。本質(zhì)上,執(zhí)行的還是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); } ?>
我們最關(guān)鍵,就是對此接口進行實現(xiàn)。完成對象和SQL的轉(zhuǎn)換。
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() { //根據(jù)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){ //獲得數(shù)據(jù)表的列名 $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){ //獲得數(shù)據(jù)表的列名 $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)){ //是數(shù)字 $sql .= $value.","; }else{ $sql .= "'".$value."',"; } } $sql = substr($sql,0,strlen($sql)-1); $sql .= ")"; //執(zhí)行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){ //是數(shù)字 if(preg_match("/^[0-9]*$/", $value)){ $sql .= $columns[0]."=".$value; }else{ $sql .= $columns[0]."='".$value."'"; } //執(zhí)行 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."'"; } //執(zhí)行操作 mysqli_query($conn,$sql); $tag = true; mysqli_close($conn); } return $tag; } } ?>
那么,對tb_user表進行操作時,主要利用的是TbUserDAO,它將modelName設(shè)置為"TbUser",代碼就得知操作的表為tb_user,然后就可以進行一系列操作了。
<?php require_once("BasicDAO.php"); require_once("../model/TbUser.php"); class TbUserDAO extends BasicDAO{ function TbUserDAO(){ $this->modelName = 'TbUser'; parent::init(); } } ?>
那么,就可以采用面向?qū)ο蟮姆绞綄?shù)據(jù)庫進行操作了。
如:
$tbUserDAO = new TbUserDAO(); $tbUser = new TbUser(); $tbUser->setUserid("fetchingsoft@163.com"); $tbUser->setUsername("fetching"); $tbUserDAO->update($tbUser); echo "執(zhí)行成功!"; print_r($list);
這樣對數(shù)據(jù)庫中的記錄進行更新。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫程序設(shè)計技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
- Php連接及讀取和寫入mysql數(shù)據(jù)庫的常用代碼
- PHP連接和操作MySQL數(shù)據(jù)庫基礎(chǔ)教程
- php mysql數(shù)據(jù)庫操作類
- PHP備份/還原MySQL數(shù)據(jù)庫的代碼
- php實現(xiàn)mysql數(shù)據(jù)庫備份類
- 常用的PHP數(shù)據(jù)庫操作方法(MYSQL版)
- php連接mysql數(shù)據(jù)庫代碼
- PHP實現(xiàn)PDO的mysql數(shù)據(jù)庫操作類
- php實現(xiàn)MySQL數(shù)據(jù)庫備份與還原類實例
- 一款簡單實用的php操作mysql數(shù)據(jù)庫類
- PHP數(shù)據(jù)庫操作之基于Mysqli的數(shù)據(jù)庫操作類庫
- 全新的PDO數(shù)據(jù)庫操作類php版(僅適用Mysql)
相關(guān)文章
使用php+Ajax實現(xiàn)唯一校驗實現(xiàn)代碼[簡單應(yīng)用]
使用php+Ajax實現(xiàn)唯一校驗實現(xiàn)代碼[簡單應(yīng)用],前臺用ajax后臺用php,需要的朋友可以參考下。2011-11-11set_include_path和get_include_path使用及注意事項
set_include_path 設(shè)置默認包含路徑,本文將介紹下其的使用方法,及注意事項,感興趣的朋友可以了解下,或許對你學習php有所幫助2013-02-021億條數(shù)據(jù)如何分表100張到Mysql數(shù)據(jù)庫中(PHP)
這篇文章主要介紹了當數(shù)據(jù)量猛增的時候如何把一億條數(shù)據(jù)分表100張到Mysql數(shù)據(jù)庫中,需要的朋友可以參考下2015-07-07