thinkphp学习08-数据库的链式查询

前面课程中我们通过指向符号"->"多次连续调用方法称为:链式查询,当 Db::name('user')时,返回查询对象(Query),即可连缀数据库对应的方法,而每次执行一个数据库查询方法时,比如 where(),还将返回查询对象(Query),只要还是数据库对象,那么就可以一直使用指向符号进行链式查询,再利用 find()、select()等方法返回数组(Array)或数据集对象(Colletion),而 find()和 select()是结果查询方法(放在最后),并不是链式查询方法

php 复制代码
public function index()
{
    $user = Db::name('user')->where('id', 27)->order('id', 'desc')->find();
    dump($user);
}

有多少种类似 where()的链式操作方法呢,官方文档

如果多次使用数据库查询,那么每次静态创建都会生成一个实例,造成浪费, 我们可以把对象实例保存下来,再进行反复调用即可

php 复制代码
public function index()
{
   $userQuery = Db::name('user');
   $dataFind = $userQuery->where('id', 5)->find();
   dump($dataFind);
   $dataSelect = $userQuery->select();
   dump($dataSelect);
}

当同一个对象实例第二次查询后,会保留第一次查询的值

php 复制代码
public function index()
{
    $userQuery = Db::name('user');
    $data1 = $userQuery->order('id', 'desc')->select();
    echo  Db::getLastSql();
    $data2 = $userQuery->select();
    echo "<br>";
    echo Db::getLastSql();;
}

使用 removeOption()方法,可以清理掉上一次查询保留的值

php 复制代码
public function index()
{
    $userQuery = Db::name('user');
    $data1 = $userQuery->order('id', 'desc')->select();
    echo  Db::getLastSql();
    $userQuery->removeOption('order')->select();
    $data2 = $userQuery->select();
    echo "<br>";
    echo Db::getLastSql();;
}
相关推荐
·present·几秒前
射频网课第三章学习(功率增益设计)
学习
毕设十刻4 分钟前
基于Vue的养老服务平台85123(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
liulanba5 分钟前
AI Agent技术完整指南 第二部分:开发框架
网络·数据库·oracle
X.Ming 同学13 分钟前
深度解析 Qt 自定义图表视图:频谱图 的设计与高级功能拓展
服务器·网络·数据库
程序猿_极客14 分钟前
【node期末作业开发】Node.js+MySQL 实现销售信息管理系统的增删改查(附源码)
数据库·mysql·node.js
liliangcsdn16 分钟前
MySQL存储字节类数据的方案示例
java·前端·数据库
d111111111d17 分钟前
STM32 I2C通信详解:从机地址 vs 寄存器地址
笔记·stm32·单片机·嵌入式硬件·学习·模块测试
qq_3660862219 分钟前
sql server 整数转百分比
运维·服务器·数据库
oMcLin20 分钟前
如何排查 Linux 系统服务器的性能故障问题:使用 `top`、`htop`、`iostat` 等工具
linux·服务器·数据库
Howrun77720 分钟前
Linux进程通信---4---信号量System V & POSIX
linux·数据库