...   1.将字符串转换成小写

strtolower(): 该函数将传入的字符串参数所有的字符都转换成小写,并以小定形式放回这个字符串

2.将字符转成大写

strtoupper(): 该函数的作用...

ORM----Oriented Relationship Mapper,即用面向对象的方式来操作数据库。归根结底,还是对于SQL语句的封装。本文我们主要和大家介绍PHP基于ORM方式操作MySQL数据库,结合具体实例形式分析了php针对mysql数据库常用操作的封装与使用技巧,希望对大家有用。

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

我们希望能够对这张表,利用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);

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

相关推荐:

ThinkPHP 之 ORM操作和关联模型_PHP教程

php mysql orm_PHP基于ORM操作MySQL数据库 - strtolower相关推荐

  1. python mysql 基于 sqlalvhrmy_Python基于DB-API操作MySQL数据库过程解析

    Python提供了一个标准数据库API,称为DB-API,用于处理基于SQL的数据库. 与任何底层数据库的交互都可以使用DB-API,因为DB-API在代码与驱动程序之间提供了一个抽象层,可以根据需要 ...

  2. Spring boot(web 组件,ORM 操作 MySQL,接口架构风格—RESTful,集成 Redis,集成 Dubbo,打包)

    文章目录 1.3 第三章 Spring Boot 和 web 组件 1.3.1 SpringBoot 中拦截器 1.3.2 Spring Boot 中使用 Servlet 1.3.3 Spring B ...

  3. JSP基于JDBC操作MSSQL2008数据库

    JSP基于JDBC操作MSSQL2008数据库 在JSP 中可以使用JDBC 技术,实现对数据库中表记录的查询.修改和删除等操作.JDBC 技术在JSP 开发中占有很重要的地位. JDBC(Java ...

  4. ruby mysql 占位符_ruby操作常用数据库

    使用Ruby DBI模块 目录 Ruby DBI模块为ruby程序访问数据库提供了一个与数据库无关的接口,就像perl的DBI模块一样.这篇文章将讲述如何编写基于DBI的ruby程序.这篇文章是对DB ...

  5. mysql flaskalchemy_Flask使用Flask-SQLAlchemy操作MySQL数据库

    前言: Flask-SQLAlchemy是一个Flask扩展,简化了在Flask程序中使用SQLAlchemy的操作.SQLAlchemy是一个很强大的关系型数据库框架,支持多种数据库后台.SQLAl ...

  6. mysql怎么防止误操作_MySQL数据库防止人为误操作的实例讲解

    有不少开发人员在操作MySQL数据库的时候都遇到过误操作的情况,例如更新数据库的时候update语句忘记加上where条件,就会造成极为悲剧的结果.本文就针对防止MySQL数据库误操作的方法做出如下详 ...

  7. php mysql 替换 pdo,php操作MySQL数据库之PDO方式

    这篇文章主要介绍了关于php操作MySQL数据库之PDO方式 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下基本使用 1)连接数据库$pdo = new PDO("mysql ...

  8. mysql一些基本sql操作_MySql数据库的一些基本操作---------------SQL语法

    MySql数据库是比较常用的关系型数据库,操作用的是sql语句,下面来说一说MySql的一些基本操作 MySql数据库是一种C/S型的模式,即客户端/服务器端,对应到具体应用上,便是bin目录下的my ...

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

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

  10. android查询mysql并显示_Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解...

    本文实例讲述了Android操作SQLite数据库(增.删.改.查.分页等)及ListView显示数据的方法.分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识记录 ...

最新文章

  1. pytorch reshape_PyTorch中的contiguous
  2. 水环境模型与大数据技术融合研究
  3. 《MarkDown》语法笔记
  4. 运维工程师之-MySQL的故障问题总结
  5. dlink虚拟服务器端口转发,D-Link路由器端口转发怎么设置【图文教程】
  6. Context Menu控件
  7. 微信公众号推送封面尺寸
  8. 蘑菇租房java,租房经历总结-----我是如何2天找到合适租房的(房东直租)简单粗暴...
  9. Java23种设计模式——2.创建型模式之原型模式
  10. python的语言是开源的_python语音识别 开源_DaCiDian是一个开源的中文普通话词汇,用于自动语音识别(ASR)....
  11. 【思维导图】canny滤波 原理步骤细致剖析
  12. 不使用羊角曲线绘制G2圆角
  13. 【Kaggle竞赛】Kaggle竞赛了解
  14. Microduino王镇山:将物联网带进课堂
  15. Nodeparty-SZ-1 深圳聚会活动回顾总结[2012.01.08] - CNode
  16. 中国人越来越不愿买新车!二手车电商上半年融资150亿元,谁是大赢家?
  17. 时间序列(一):上手体验
  18. android自带的nsd发现服务器,Android NSD(网络服务发现)是否与iOS中的Bonjour服务兼容?...
  19. 银行信息科技岗:中原银行算法工程师面试分享
  20. 浅谈 TLS 1.3

热门文章

  1. ardupilot-3.6.9 stabilize模式下(增稳模式)油门输入输出整理
  2. 软件生命周期和开发模型
  3. so库方法的调用过程
  4. 树莓派3B+安装系统(Raspbian)以及配置环境
  5. 【 C++ 】日期计算器
  6. 基于MFCC参数的元音识别
  7. vue自动计算日期天数
  8. php --enable-maintainer-zts,我的PHP编译日志
  9. 合肥工业大学计算机信息学院,合肥工业大学计算机与信息学院在职研究生_合肥工业大学在职研究生_125在职研究生...
  10. OPC服务器简介和入门介绍