如何使用thinkphp5.1的数组查询对象

用过5.0的开发者都比较依赖5.0的数组查询方式,但是很无奈5.1的数组查询方式和5.0的区别很大,因此经常听到开发者抱怨5.1的数组查询不好用。

首先,出于安全和易用性的原因,官方是不推荐使用数组查询条件的,其次,你也许不知道5.1版本其实提供了一个新的数组对象查询的方式用以替代之前的数组条件。如果你的版本是V5.1.21+的话,那么可以尝试下面提到的数组对象查询方式,一定会有意外的惊喜^_^

对于习惯或者重度依赖数组查询条件的用户来说,可以选择数组对象查询,该对象完成了普通数组方式查询和系统的查询表达式之间的桥接,但相较于系统推荐的查询表达式方方式而言,需要注意变量的安全性,避免产生sql注入的情况。

要使用数组对象查询,你首先需要引入thinkdbWhere类。

use thinkdbWhere;

Where对象的用法一般有两种,第一种最简单,你依然和5.0一样使用数组条件进行定义查询条件,例如:

$map = [    'name'   => ['like', 'thinkphp%'],    'title'  => ['like', '%think%'],    'id'     => ['>', 10],    'status' => 1,];

然后,在实际使用where方法的时候改为

Db::name('user')    ->where(new Where($map))    ->select();

生成的SQL是:

立即学习“PHP免费学习笔记(深入)”;

SELECT * FROM `think_user` WHERE  `name` LIKE 'thinkphp%' AND `title` LIKE '%think%' AND  `id` > 10  AND `status` =1

这种方式最容易改造,相当于一键切换到5.0的数组查询方式。当然,除了Db查询之外,模型查询也一样可以支持。

第二种方式是,直接实例化一个Where对象,然后在where方法查询的时候直接传入该Where对象实例。

$where          = new Where;$where['id']    = ['in', [1, 2, 3]];$where['title'] = ['like', '%php%'];Db::name('user')    ->where($where)    ->select();

Where对象实现了ArrayAccess接口,因此可以直接当成数组来赋值。

蓝心千询 蓝心千询

蓝心千询是vivo推出的一个多功能AI智能助手

蓝心千询 34 查看详情 蓝心千询

生成的SQL是:

立即学习“PHP免费学习笔记(深入)”;

SELECT * FROM `think_user` WHERE   `id` IN (1,2,3) AND `title` LIKE '%php%'

使用Where对象查询可以和其它的查询方式混合使用。如果你在混合使用数组查询对象的时候,希望某个数组查询对象的查询条件加上括号,可以使用

$where          = new Where;$where['id']    = ['in', [1, 2, 3]];$where['title'] = ['like', '%php%'];Db::name('user')    ->where($where->enclose())    ->where('status', 1)    ->select();

生成的SQL是:

立即学习“PHP免费学习笔记(深入)”;

SELECT * FROM `think_user` WHERE  ( `id` IN (1,2,3) AND `title` LIKE '%php%' ) AND  `status` =1

enclose方法表示该查询条件两边会加上括号包起来。

使用数组对象查询的情况请一定要注意做好数据类型检查,尽量避免让用户决定你的数据,从而导致SQL注入的可能。

相关推荐:最新的10个thinkphp视频教程

以上就是如何使用thinkphp5.1的数组查询对象的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/345957.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫

关于作者

上一篇 2025年11月5日 20:22:20
下一篇 2025年11月5日 20:26:27

相关推荐

发表回复

登录后才能评论
关注微信