首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
ThinkPHP如何使用ThinkOrm封装_ThinkOrm数据库封装方法【指南】

ThinkPHP如何使用ThinkOrm封装_ThinkOrm数据库封装方法【指南】

热心网友
98
转载
2026-05-06

一、引入 ThinkOrm 独立包并初始化连接

如果你正在寻找一个轻量、独立且能兼容多种数据库的ORM方案,又不想为了它而引入整个ThinkPHP框架,那么ThinkOrm的封装方案正好能派上用场。它本质上是一个剥离出来的PDO抽象层,开箱即用。具体怎么操作呢?咱们一步步来看。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

首先,ThinkOrm是从ThinkPHP 5.1的ORM核心中独立出来的,它支持包括MySQL、Pgsql、Sqlite、SqlServer、Oracle乃至MongoDB在内的多种数据库驱动。最大的好处是,它不依赖任何框架容器,只需要引入自动加载器并完成基础配置,就能立刻跑起来。

第一步,通过Composer安装这个独立包:composer require thinkyaf/thinkorm

第二步,在你的项目入口文件或者服务初始化的地方,引入Composer的自动加载器:require ‘vendor/autoload.php’;

ThinkPHP如何使用ThinkOrm封装_ThinkOrm数据库封装方法【指南】

第三步,使用Db类手动创建一个数据库连接实例。配置方式非常直观,比如连接MySQL:use think\Db; $db = Db::connect([‘type’=>‘mysql’,‘hostname’=>‘127.0.0.1’,‘database’=>‘test’,‘username’=>‘root’,‘password’=>’’]);

完成这三步,你的独立ORM环境就搭建好了。

二、使用查询构造器执行链式操作

连接建立后,怎么操作数据库呢?ThinkOrm提供了一套与ThinkPHP风格高度一致的查询构造器接口。所有操作都从Db::table()开始,它返回一个Query实例,让你可以流畅地进行链式调用。这种方式特别适合那些不需要复杂模型映射的快速查询场景。

来看几个典型的例子:

执行一个基础的条件查询并排序:Db::table(‘user’)->where(‘status’, 1)->order(‘id’, ‘desc’)->limit(10)->select();

插入一条新记录:Db::table(‘user’)->data([‘name’=>‘Alice’,‘email’=>‘a@example.com’])->insert();

更新符合条件的数据:Db::table(‘user’)->where(‘id’, 5)->update([‘last_login’=>date(‘Y-m-d H:i:s’)]);

删除记录,并获取影响的行数:Db::table(‘log’)->where(‘created_at’, ‘delete();

可以看到,语法非常简洁明了,几乎没有任何学习成本。

三、定义模型类并启用 ORM 映射

当然,如果你的业务逻辑更复杂,需要用到数据验证、模型事件、关联关系或者自动时间戳这些高级功能,那么定义独立的模型类就是更好的选择。好消息是,ThinkOrm的模型类可以完全脱离ThinkPHP标准的application目录结构,只要保证命名空间和自动加载规则匹配,放在任何位置都可以。

具体怎么做?

首先,创建一个模型文件,例如User.php,路径可以自定义,比如放在app/model/目录下:

namespace app\model; use think\Model; class User extends Model { protected $table = ‘user’; }

定义好后,在代码中就可以直接使用静态方法进行操作了:app\model\User::where(‘id’, 1)->find();

也可以实例化后操作,模型会自动处理时间戳等字段:$user = new app\model\User(); $user->name = ‘Bob’; $user->sa ve();

还有一个非常实用的功能是软删除。只需在模型中引入对应的Trait并设置删除时间字段,查询时就会自动过滤掉已“删除”的数据:

use think\model\concern\SoftDelete; class User extends Model { use SoftDelete; protected $deleteTime = ‘delete_time’; }

四、配置多数据库连接与读写分离

对于需要应对更高并发或数据分布在不同数据库的场景,ThinkOrm同样提供了灵活的支持。它允许在运行时动态切换连接,无论是为了实现读写分离,还是进行跨库联合查询,都能轻松应对。

关键在于配置和管理多个连接。你可以先定义一个包含主从库信息的配置数组:

$configs = [‘master’=>[‘type’=>‘mysql’,‘hostname’=>‘master.host’],‘sla ve’=>[‘type’=>‘mysql’,‘hostname’=>‘sla ve.host’]];

进行只读查询时,可以显式指定使用从库连接:Db::connect($configs[‘sla ve’])->table(‘user’)->where(‘id’, 1)->find();

对于模型,你可以通过设置connection属性将其绑定到特定的连接配置上:class Order extends Model { protected $connection = ‘master’; }

最后,需要特别注意的是事务操作。事务内的所有数据库操作,必须确保在同一个连接实例上执行,否则会出错。标准的写法是这样的:

$db = Db::connect($configs[‘master’]); $db->startTrans(); try { $db->table(‘account’)->where(‘id’,1)->dec(‘balance’, 100); $db->table(‘log’)->insert([‘action’=>‘deduct’]); $db->commit(); } catch (\Exception $e) { $db->rollback(); throw $e; }

遵循这个模式,就能安全地处理跨表事务了。

来源:https://www.php.cn/faq/2425109.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

PHP如何实现数组去重保留键名_PHP实现数组去重保留键名方法【操作】
编程语言
PHP如何实现数组去重保留键名_PHP实现数组去重保留键名方法【操作】

PHP数组去重保留键名:五种方法深度解析 在PHP开发实践中,数组去重是一项常见需求。然而,许多开发者会遇到一个棘手问题:使用常规方法去重后,数组的键名被重新索引,导致原有的关联关系丢失。标准的array_unique()函数在处理关联数组时虽能保留键名,但其默认的字符串比较方式可能引发类型隐式转换

热心网友
05.06
PHP如何防止点击劫持攻击_PHP防止点击劫持攻击方法【安全】
编程语言
PHP如何防止点击劫持攻击_PHP防止点击劫持攻击方法【安全】

PHP如何防止点击劫持攻击:五种协同防护策略详解 如果你的PHP应用页面被发现可以被随意嵌入到第三方网站的iframe中,甚至可能诱导用户进行非本意的操作,那么这很可能就是点击劫持攻击在“敲门”了。这种安全漏洞的危害不容小觑,但好在,我们可以通过一套组合拳来有效防御。下面要介绍的,正是五种经过验证、

热心网友
05.06
PHP函数如何利用非统一内存访问优化_PHP适配NUMA硬件架构【方法】
编程语言
PHP函数如何利用非统一内存访问优化_PHP适配NUMA硬件架构【方法】

PHP函数如何利用非统一内存访问优化_PHP适配NUMA硬件架构【方法】 先说一个核心结论:PHP函数本身,无法直接利用非统一内存访问(NUMA)架构来优化性能。 这听起来可能有点反直觉,但原因在于PHP的运行机制。它运行在Zend虚拟机之上,所有的内存分配,无论是通过glibc的malloc还是P

热心网友
05.06
PHP怎样实现闭包函数传参_PHP实现闭包函数传参方法【函数式】
编程语言
PHP怎样实现闭包函数传参_PHP实现闭包函数传参方法【函数式】

PHP闭包传参:动态输入与固化上下文的双轨制 深入探讨PHP闭包的参数传递机制,其核心可归结为两条相辅相成的路径:动态参数传递与上下文固化捕获。前者在调用闭包时实时传入可变数据,后者则通过use关键字在定义时锁定外部环境变量。这两种方式并非互斥,而是构成了PHP闭包灵活处理数据的“双轨制”,分别应对

热心网友
05.06
PHP怎样实现字符串反转功能_PHP实现字符串反转功能方法【文本】
编程语言
PHP怎样实现字符串反转功能_PHP实现字符串反转功能方法【文本】

PHP怎样实现字符串反转功能_PHP实现字符串功能方法【文本】 在PHP开发中,字符串反转是一个常见且实用的操作需求。无论是处理用户输入、数据格式化还是算法实现,掌握多种字符串反转方法都至关重要。本文将系统性地讲解PHP中实现字符串反转的十二种核心技巧,涵盖从内置函数、基础循环到高级算法与多字节安全

热心网友
05.06

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

史上最长寿标准版!iP17生产周期延长:苹果刀法变了
科技数码
史上最长寿标准版!iP17生产周期延长:苹果刀法变了

iPhone 17:为何成为苹果史上最长寿的爆款? 最近科技圈有个消息传得挺热:iPhone 17标准版的生产周期被大幅拉长了。这可不是简单的产能调整,背后是苹果近期完成的大规模产能扩展。看来,这款热门机型已经瞄准了今年下半年的双11战场,准备再掀一波销售热潮。 消息一出,不少网友都在猜测原因。矛头

热心网友
05.06
小米有品新款mini智能电动平衡车深度体验:便携智能,解锁城市出行新方式
科技数码
小米有品新款mini智能电动平衡车深度体验:便携智能,解锁城市出行新方式

在快节奏的都市生活中,一款兼具便携性与环保特性的出行工具正成为越来越多人的选择 城市通勤的“最后一公里”难题,催生了对灵活出行方案的持续探索。近期,小米有品推出的mini智能电动平衡车,以其独特的设计理念和深度智能化功能,迅速吸引了市场的目光。它不仅仅是一款酷玩装备,更切实地为青少年和上班族提供了高

热心网友
05.06
护眼与智能兼备:科大讯飞AI学习机深度评测,为孩子选对学习好帮手
科技数码
护眼与智能兼备:科大讯飞AI学习机深度评测,为孩子选对学习好帮手

在数字化教育蓬勃发展的当下,家长们为孩子挑选学习设备时,既希望设备具备护眼功能,又期望能满足多样化的学习需求。传统平板电脑功能虽丰富,但长时间使用易引发视力疲劳;普通学习机功能又相对单一,难以契合现代教育的发展趋势。在此背景下,科大讯飞AI学习机系列凭借先进的护眼技术与智能学习系统,成为众多家长和学

热心网友
05.06
以太坊(ETH)财库黑马ETHZilla解析:蒂尔和EF深度加持 mNAV高达6
web3.0
以太坊(ETH)财库黑马ETHZilla解析:蒂尔和EF深度加持 mNAV高达6

目录 ethzilla是谁? ETHZilla独特其他ETH DAT之处 1、Peter Thiel持股ETHZilla近30% 2、Vitalik和以太坊基金会入局 3、聚焦DeFi和链上策略 结语 以太坊财库概念的热度,最近真是肉眼可见。伴随着这股热潮,ETH价格也强势突破了4700美元,距离历

热心网友
05.06
国内彩电一年仅卖2763万台 创10年新低
科技数码
国内彩电一年仅卖2763万台 创10年新低

全球彩电市场:存量博弈下的冰与火之歌 最近,行业调研机构奥维睿沃(A VC Revo)发布了一份引人关注的报告,揭示了2025年全球彩电市场的真实图景。数据显示,全球彩电整体出货量达到2 64亿台,同比仅微跌0 1%,市场基本盘看似稳固。 然而,拆开来看,内部结构正在发生深刻变化。LCD液晶电视依然

热心网友
05.06