首页 php框架 ThinkPHP thinkphp中什么是orm

thinkphp中什么是orm

Feb 14, 2022 pm 05:04 PM
orm thinkphp

在thinkphp中,ORM指的是“对象关系映射”,是为方便开发者使用数据库开发的一个存储访问层;ORM的主要用途是把对象模型表示的对象映射到基于sql的关系模型数据库结构中去。

thinkphp中什么是orm

本教程操作环境:Windows7系统、thinkphp v5.1版、Dell G3电脑。

thinkphp中的orm

ORM的全称是Object Relational Mapping,即对象关系映射

  • O(Object) 对象,在项目中就是实体,更加精确的来说就是数据Model,也可以说持久化类。

  • R(Relation) 关系数据

  • M (Mapping)映射,将对象映射到关系数据,将关系数据映射到对象的过程。

更加直观理解就是,ORM 就是以OOP思想,产生增删改查SQL语句。

ThinkPHP的ORM是为方便开发者使用数据库开发的一个存储访问层,框架设计图片如下:

thinkphp中什么是orm

主要用途是:把对象模型表示的对象映射到基于sql的关系模型数据库结构中去。

当改变这个对象自身的属性或者调用该对象的方法时,相对应的是执行某些sql语句。

这样子编写代码的人员就可以更好地编写业务逻辑,而非重复地编写增删改查sql语句。

thinkphp中的运用示例

TP框架中关于数据库操作有两个模块:

  • 数据库

  • 模型

tp中的数据库模块

引用一句文档的特性描述

拆分为Connection(连接器)/Query(查询器)/Builder(SQL生成器)

  • Connection连接器主要是用来连接数据库的,可以使用不同的驱动连接不同类型的数据库。

  • Query查询器则是用来运行sql语句,处理结果,映射到数据集中。

  • Builder生成器则是用来把我们传递进去的条件、排序等转换成sql语句。

在这3个步骤中,我们可以知道,如果有运用到ORM思想抽象映射的,那就只可能是Query查询器模块,但是我们可以细查TP文档中关于数据集的描述。

它更多的是封装提供对于数据的处理方法,比如:

(以下是从文档复制过来的  一小部分)

toArray     将数据集的数据转为数组
merge   合并其它数据
diff    比较数组,返回差集
flip    交换数据中的键和值
intersect   比较数组,返回交集
keys    返回数据中的所有键名
pop 删除数据中的最后一个元素
shift   删除数据中的第一个元素
unshift 在数据开头插入一个元素
reduce  通过使用用户自定义函数,以字符串返回数组
登录后复制

但是却没有提供反向映射的关系操作,比如我们操作数据集,自动更新数据库中的数据。

所以在我的理解中,数据库模块中的ORM思想并不多,重点还是要了解和运用模型

tp中的模型

定义模型文件

namespace app\index\model;

use think\Model;

// 设置类名 需要遵循转换规则,蛇形转为大驼峰
class User extends Model
{
    // 设置主键字段名
    protected $pk = 'u_id';

    // 开启自动维护时间戳字段 (什么时间插入 什么时间更新)
    protected $autoWriteTimestamp = true;

    // 软删除 开启之后 删除数据只是用一个字段来标识为删除状态 方便查询、备份等
    use SoftDelete;
    protected $deleteTime = 'delete_time';

}
登录后复制

以上代码比文档中第一章节模型初始化要多了一些内容,这是为了突出 模型可以完成很多功能

这也是ORM出现的原因:将sql的执行,抽象映射为面向对象编程中的对象。

我们可以理解为:表中的一行数据,代表我们代码中new一个对象,改变对象,则自动更新表中对应的行。

使用模型

演示的代码是比较简单的,实际是可以很灵活的

比如查询用非主键的条件来查询、查询多行记录等等

<?php
// *******快速查询、更新*******
// 查询主键=1的数据
$user = User::get(1);
// 然后更改它的name字段为新的值
$user->name = &#39;thinkphp&#39;;
// 保存,自己去数据库给我更新吧~
$user->save();

// *******插入新的一行数据*******
// 新建一个对象(相对应的操作就是新创建一行)
$user = new User;
// 设置字段的值  有多个字段就多个设置
$user->name= &#39;thinkphp&#39;;
// 保存,自己去插入吧~
$user->save();
登录后复制

误区

看了使用之后,很多初学者就开始写代码了,然而却使用了不太正确的方式。

① model只当为Db类用

虽然model可以看成db类的超集,但是如果只是把它当成简单的DB类使用,而不是使用ORM思想去编写。那么就没什么必要使用它了。。

如果使用不对,不仅不能提高效率,反而会影响自己。(比如代码规范不统一、新增表还要新增对应的模型文件等等)

代码演示:

<?php
$userModel = new User(); // 这里就相当于初始化Db类
$userOneInfo = $userModel->where([&#39;u_id&#39; => 1])->find();

$userTwoInfo = $userModel->where([&#39;u_id&#39; => 2])->find();
// ... 执行其他逻辑 比如判断上下级 操作权限等等

// 业务需求不只是读取用户的数据这么简单
// 还要扣除余额(就是更新数据库)
$userOneRes = $userModel->where([&#39;u_id&#39; => 1])->update([&#39;u_balance&#39; => &#39;xxxx&#39;]);

// ... 执行其他逻辑
登录后复制

看到这里,先停下来思考一下。。你的代码有出现过这样子的吗?

我相信还是有些人会这样子用的吧!因为我以前也是这样子用的。

那么我们看看正确的使用方法(我认为的,如果觉得不对或者有更好的,欢迎评论交流)

<?php

$userOneInfo = User::get(1);

// 这里演示使用非主键条件查询的情况!!
// 查询一个1用户的下级出来
$userTwoInfo = User::get(function($query){
    $query->where([&#39;p_uid&#39; => 1]);
});

// ... 执行其他逻辑 比如判断上下级 操作权限等等

// 业务需求不只是读取用户的数据这么简单
// 还要扣除余额(就是更新数据库)
$userOneInfo->u_balance = 0;
$userOneRes = $userOneInfo->save();

$userTwoInfo->u_balance = 0;
$userTwoRes =  $userTwoInfo->save();

// ... 执行其他逻辑
登录后复制

因为一个对象映射一条数据,所以我们在操作同样where条件的数据,直接操作对象就可以了, 就不用反复编写where u_id =1更新, u_id = 1 要删除

使用模型,还有很多用处,(得益于开源团队的奉献,为我们封装了大量的功能)

比如: 

 – 用户表新增一条数据,另一个附属表也要用该用户id初始化一行。

 – 自动转换数据格式(储存时间戳,查询出来为2019-7-13 19:53:04格式)。

 – 自动校验数据,自动完成数据(操作的时候默认取操作人ip 权限等储存)。

 – 关联查询(TP中非常强大的功能,在模型中定义好与另一个模型的关系,比如店铺表中的u_id 可以用来查询出店铺所属用户的信息  相当于店铺模型和用户模型的关联  自动join数据 合并 返回给我们使用)

 – 等等

总结

ORM是一种思想,概念,代表 对象-关系映射(数据库-对象 映射)ORM使得对数据的操作抽象为对对象的操作。要学会思想的改变,利用好框架提供的特性,编写更好地代码。TP中的模型非常强大,封装了大量的逻辑。

【相关教程推荐:thinkphp框架

以上是thinkphp中什么是orm的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1663
14
CakePHP 教程
1420
52
Laravel 教程
1315
25
PHP教程
1266
29
C# 教程
1239
24
thinkphp项目怎么运行 thinkphp项目怎么运行 Apr 09, 2024 pm 05:33 PM

运行 ThinkPHP 项目需要:安装 Composer;使用 Composer 创建项目;进入项目目录,执行 php bin/console serve;访问 http://localhost:8000 查看欢迎页面。

thinkphp有几个版本 thinkphp有几个版本 Apr 09, 2024 pm 06:09 PM

ThinkPHP 拥有多个版本,针对不同 PHP 版本而设计。主要版本包括 3.2、5.0、5.1 和 6.0,而次要版本用于修复 bug 和提供新功能。当前最新稳定版本为 ThinkPHP 6.0.16。在选择版本时,需考虑 PHP 版本、功能需求和社区支持。建议使用最新稳定版本以获得最佳性能和支持。

thinkphp怎么运行 thinkphp怎么运行 Apr 09, 2024 pm 05:39 PM

ThinkPHP Framework 的本地运行步骤:下载并解压 ThinkPHP Framework 到本地目录。创建虚拟主机(可选),指向 ThinkPHP 根目录。配置数据库连接参数。启动 Web 服务器。初始化 ThinkPHP 应用程序。访问 ThinkPHP 应用程序 URL 运行。

PHP中如何使用对象-关系映射(ORM)简化数据库操作? PHP中如何使用对象-关系映射(ORM)简化数据库操作? May 07, 2024 am 08:39 AM

使用ORM可简化PHP中的数据库操作,它将对象映射到关系数据库中。Laravel中的EloquentORM允许使用面向对象的语法与数据库交互,可通过定义模型类、使用Eloquent方法或在实战中构建博客系统等方式来使用ORM。

laravel和thinkphp哪个好 laravel和thinkphp哪个好 Apr 09, 2024 pm 03:18 PM

Laravel 和 ThinkPHP 框架的性能比较:ThinkPHP 性能通常优于 Laravel,专注于优化和缓存。Laravel 性能良好,但对于复杂应用程序,ThinkPHP 可能更适合。

thinkphp怎么安装 thinkphp怎么安装 Apr 09, 2024 pm 05:42 PM

ThinkPHP 安装步骤:准备 PHP、Composer、MySQL 环境。使用 Composer 创建项目。安装 ThinkPHP 框架及依赖项。配置数据库连接。生成应用代码。启动应用并访问 http://localhost:8000。

Hibernate 如何实现多态映射? Hibernate 如何实现多态映射? Apr 17, 2024 pm 12:09 PM

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

thinkphp性能怎么样 thinkphp性能怎么样 Apr 09, 2024 pm 05:24 PM

ThinkPHP 是一款高性能的 PHP 框架,具备缓存机制、代码优化、并行处理和数据库优化等优势。官方性能测试显示,它每秒可处理超过 10,000 个请求,实际应用中被广泛用于京东商城、携程网等大型网站和企业系统。

See all articles