iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >怎么使用thinkphp5.1的数组查询对象
  • 246
分享到

怎么使用thinkphp5.1的数组查询对象

2023-06-20 14:06:56 246人浏览 安东尼
摘要

这篇文章主要介绍怎么使用thinkPHP5.1的数组查询对象,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!教你使用5.1的数组查询对象用过5.0的开发者都比较依赖5.0的数组查询方式,但是很无奈5.1的数组查询方式和

这篇文章主要介绍怎么使用thinkPHP5.1的数组查询对象,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

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

首先,出于安全和易用性的原因,官方是不推荐使用数组查询条件的,其次,你也许不知道5.1版本其实提供了一个新的数组对象查询的方式用以替代之前的数组条件。

如果你的版本是V5.1.21+的话,那么可以尝试下面提到的数组对象查询方式,一定会有意外的惊喜^_^

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

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

use think\db\Where;

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

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

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

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

生成的SQL是:

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接口,因此可以直接当成数组来赋值。

生成的SQL是:

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是:

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

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

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

以上是“怎么使用thinkphp5.1的数组查询对象”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网PHP编程频道!

--结束END--

本文标题: 怎么使用thinkphp5.1的数组查询对象

本文链接: https://www.lsjlt.com/news/297479.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么使用thinkphp5.1的数组查询对象
    这篇文章主要介绍怎么使用thinkphp5.1的数组查询对象,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!教你使用5.1的数组查询对象用过5.0的开发者都比较依赖5.0的数组查询方式,但是很无奈5.1的数组查询方式和...
    99+
    2023-06-20
  • ADO.NET对象查询怎么使用
    这篇文章主要介绍“ADO.NET对象查询怎么使用”,在日常操作中,相信很多人在ADO.NET对象查询怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ADO.NET对象查询怎么使用”的疑惑有所帮助!接下来...
    99+
    2023-06-17
  • thinkphp5 使用模型查询对象类型转数组
    在ThinkPHP5中,可以使用模型的toArray方法将查询结果对象类型转换为数组类型。以下是一个例子:1. 假设有一个User模...
    99+
    2023-10-11
    php
  • php怎么使用json对象数组
    JSON是一种常见的数据格式,它以一种易于理解的方式表示数据,方便数据的传输和解析。在PHP中,使用JSON对象数组非常方便,可以让我们快速地解析和处理JSON格式的数据。本文将详细介绍PHP如何使用JSON对象数组。一、PHP如何生成JS...
    99+
    2023-05-19
  • 怎么使用php查询多组数据
    本篇内容介绍了“怎么使用php查询多组数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、PHP查询多组数据的基本语法在PHP中,查询多组...
    99+
    2023-07-05
  • php怎么查询数组有多少key值对
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑php怎么查询数组有多少key值对查询数组有多少key值对,就是查询数组有多少元素,即数组长度。而PHP中,提供了两个函数count() 和 sizeof() 来获取数...
    99+
    2021-08-14
    php 数组 key值对
  • PHP中怎么对数组进行模糊查询
    这篇文章主要介绍“PHP中怎么对数组进行模糊查询”,在日常操作中,相信很多人在PHP中怎么对数组进行模糊查询问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP中怎么对数组进行模糊查询”的疑惑有所帮助!接下来...
    99+
    2023-07-06
  • JavaScript中怎么检查对象是否为数组
    JavaScript中怎么检查对象是否为数组,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。JS 中的非原始数据类型都是对象(函...
    99+
    2022-10-19
  • 使用ajax怎么获取json对象数组
    本篇文章为大家展示了使用ajax怎么获取json对象数组 ,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。如下所示:var obj= [{id: 1, pId:...
    99+
    2023-06-08
  • Django中常用的查询数据方法及查询对象的条件详解
    (1)常用的查询方法: 1.获取所有记录: s = User.objects.all() 2.获取第一条数据: s = User.objects.first() 3...
    99+
    2022-11-12
  • 怎么在MongoDB中对数组中的元素进行查询
    怎么在MongoDB中对数组中的元素进行查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。前言MongoDB是文档型数据库,每个文档(doc)...
    99+
    2022-10-18
  • 怎么使用PHP查询MySQL并返回数组
    这篇文章主要介绍“怎么使用PHP查询MySQL并返回数组”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用PHP查询MySQL并返回数组”文章能帮助大家解决问题。在开始之前,我们需要准备一些东西...
    99+
    2023-07-06
  • 数据库分组查询语句怎么使用
    在数据库中使用分组查询语句可以对数据进行分组并对每个分组进行聚合操作。常用的分组查询语句是使用SELECT语句结合GROUP...
    99+
    2023-09-15
    数据库
  • Vue怎么使用watch监听数组或对象
    这篇文章主要介绍“Vue怎么使用watch监听数组或对象”,在日常操作中,相信很多人在Vue怎么使用watch监听数组或对象问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue怎么使用watch监听数组或对象...
    99+
    2023-07-02
  • 怎么理解Oracle数据库中的多表查询,分组查询,子查询
    本篇内容介绍了“怎么理解Oracle数据库中的多表查询,分组查询,子查询”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能...
    99+
    2022-10-18
  • Mariadb聚合函数及分组查询怎么使用
    这篇文章主要介绍“Mariadb聚合函数及分组查询怎么使用”,在日常操作中,相信很多人在Mariadb聚合函数及分组查询怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mariadb聚合函数及分组查询怎...
    99+
    2023-06-27
  • 使用json对象转化为key,value的对象数组
    目录json对象转为key,value对象数组问题引出解决方式数组转换成json key-value形式eg1(数组中包含的是数组)eg2(数组中包含的是对象)json对象转为key...
    99+
    2022-11-13
  • php怎么查询数组元素的key
    本文操作环境:Windows10系统、PHP7.1版、Dell G3电脑。php怎么查询数组元素的keykey() 函数返回数组内部指针当前指向元素的键名。若发生错误,则函数返回 FALSE。 key() 函数用来获得数组中当前元素的键名。...
    99+
    2021-04-24
    php
  • php怎么查询数组的key(键名)
    3种方法:1、用key()函数,可查询当前数组元素的key(键名),语法“key(数组)”。2、用array_keys()函数,可以获取数组的全部key,语法“array_keys(数组)”,也可获取指定值的key,语法“array_key...
    99+
    2022-08-18
    php数组 php
  • 使用javascript怎么判断对象是否为数组
    使用javascript怎么判断对象是否为数组?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。javascript判断对象是否数组的方法:1、使用isArray方法,代码为【...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作