本文实例讲述了PHP基于ORM方式操作MySQL数据库。分享给大家供大家参考,具体如下:

ORM----Oriented Relationship Mapper,即用面向对象的方式来操作数据库。归根结底,还是对于SQL语句的封装。

首先,我们的数据库有如下一张表:

我们希望能够对这张表,利用setUserid("11111"),即可以设置userid;getUserid()既可以获得对象的userid。所以,我们需要建立model对象,与数据库中的表对应。

由于每张表所对应的model都应该是有set/get操作,所以,我们用一个父类BasicModel进行定义。其他model都是继承至这个model。

BasicModel的代码如下:

/*

* 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则对它进行继承。

require_once("BasicModel.php");

class TbUser extends BasicModel{

}

?>

这样,我们就可以对TbUser的实例进行set/get操作了。

要用ORM进行操作数据库,就必须可以findByWhere($where)进行查询,返回的为对象数组;save($tbUser)进行保存;delete($obj)进行删除;update($obj)进行更新操作。

本质上,就是用户传入的是对象,我们再利用代码将对象转换为SQL语句。本质上,执行的还是SQL语句。

所以,我们对一系列的操作用接口表示。IBasicDAO的代码如下:

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的代码如下:

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

$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,然后就可以进行一系列操作了。

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);

这样对数据库中的记录进行更新。

希望本文所述对大家PHP程序设计有所帮助。

orm mysql_PHP基于ORM方式操作MySQL数据库实例相关推荐

  1. php使用pdo操作mysql数据库实例_php5使用pdo连接数据库实例

    本文为大家介绍下php pdo的用法. 一,pdo简介 pdo(php data object) 是php 5 中加入的东西,是php 5新加入的一个重大功能,因为在php 5以前的php4/php3 ...

  2. wps连接mysql数据库增删改查_Python操作MySQL数据库实例详解【安装、连接、增删改查等】...

    本文实例讲述了python操作MySQL数据库.分享给大家供大家参考,具体如下: 1.安装 通过Python连接MySQL数据库有很多库,这里使用官方推荐的MySQL Connector/Python ...

  3. Python MySQLdb模块连接操作mysql数据库实例_python

    mysql是一个优秀的开源数据库,它现在的应用非常的广泛,因此很有必要简单的介绍一下用python操作mysql数据库的方法.python操作数据库需要安装一个第三方的模块,在http://mysql ...

  4. php mysqldb 数据库切换,Python MySQLdb模块连接操作mysql数据库实例

    mysql是一个优秀的开源数据库,它现在的应用非常的广泛,因此很有必要简单的介绍一下用python操作mysql数据库的方法.python操作数据库需要安装一个第三方的模块,在http://mysql ...

  5. php使用pdo操作mysql数据库实例_php使用PDO操作MySQL数据库实例_PHP

    本文实例讲述了php使用PDO操作MySQL数据库的方法.分享给大家供大家参考.具体分析如下: PDO是mysql数据库操作的一个公用类,我们不需要进行自定类就可以直接使用pdo来操作数据库,但是在p ...

  6. mysql jdbc实例_jdbc操作mysql数据库实例

    本文实例讲述了jdbc操作mysql数据库的方法.分享给大家供大家参考.具体如下: import java.sql.*; import java.sql.DriverManager; import j ...

  7. java操作mysql数据库实例_jdbc操作mysql数据库实例

    本文实例讲述了jdbc操作mysql数据库的方法.分享给大家供大家参考.具体如下: import java.sql.*; import java.sql.drivermanager; import j ...

  8. Python通过ORM方式操作MySQL数据库

    文章目录 ORM方式 一.Python操作MySql 1.1 读取数据 1.2 插入数据 1.3 条件查询 1.3.1 查询所有 1.3.2 查询个别 1.3.3 limit().all().one( ...

  9. .net core 3.1 mysql_.net core3.1 MVC使用sqlsugar方式操作mysql数据库

    一.创建项目 本来这个项目是写SQLite数据库的,但连接字符串,老不成功,郁闷死了,改成使用这个MySQL5.7数据库了.但大体一样的,大家能完全感觉到SqlSugar的强大. 因我是小白菜,可能写 ...

最新文章

  1. 介绍 Saltstack批量管理文件和计划任务
  2. fbx 转 gltf glb 文件
  3. android gpuimage显示的缩放和剪裁模式
  4. java enumerable_java - Java相当于C#的'Enumerable.Any' - 堆栈内存溢出
  5. java 静态类 new_java静态类new的对象是否能被回收?
  6. 在多台服务器上简单实现Redis的数据主从复制
  7. 花生问题——百练OJ:2950:摘花生与1928:The Peanuts
  8. Python 列表实现原理
  9. 谷歌,IE,火狐浏览器内核
  10. 哈哈哈,这个勒索软件笑死我了!太菜了~
  11. cv2.cvtColor报错
  12. 【C/C++】求解线性方程组的雅克比迭代与高斯赛德尔迭代
  13. springboot 实现百度小程序收银台支付功能
  14. 0ctf_2017_babyheap
  15. 关于eWebEditor-在线HTML编辑器控…
  16. 记录Widows10系统崩溃后安装Widows7系统的心酸历程
  17. 【死代码】(Dead Code)和【夸夸其谈未来性】(Speculative Generality)-如何解决被遗弃不用的代码以及暂时未被使用,但之后存在规划的代码?
  18. HTML5定稿了 为什么原生App世界将被颠覆
  19. 向量代数:向量的内积和外积
  20. 【机器学习】机器学习之一元线性回归

热门文章

  1. kafka 在 360 商业化的实践
  2. Hive UDF 中使用hdfs中的文件
  3. 深度 | 理解深度学习中的卷积
  4. ViewState的原理,应用场合,注意事项
  5. 线性条件随机场代码解读
  6. TF2 keras Tensoboard学习总结
  7. 机器学习之Stacking原理与实战
  8. 数据可视化系列(五):样式色彩秀芳华
  9. Apache CXF入门
  10. 两条边延长角会有什么变化_《认识角》教学设计