• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 如何使用thinkphp5.1的数组查询对象

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

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了thinkphp5.1,数组查询对象等相关知识,希望对您有所帮助

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

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

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

教你使用5.1的数组查询对象

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


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • ThinkPhp5.1制作微信支付以及支付后的几种状态说明
  • 你知道Thinkphp5.1让验证码在Electron-vue中怎么用?
  • Thinkphp5.1详细讲解中间件的用法
  • 如何使用thinkphp5.1的数组查询对象
  • 解决ThinkPHP5.1版本引入composer vendor扩展包的问题
  • 说说Thinkphp5.1实现邮箱验证问题
  • 详解thinkphp5.1的URL重写,伪静态设置
  • thinkphp5.1的model模型自动更新update_time字段实例讲解
  • 解决TP5.1出现A non well formed numeric value encountered的问题
  • Thinkphp5.1 + layui时间范围设置方法

相关文章

  • 2022-04-29js如何获取UEditor富文本编辑器中的图片地址
  • 2022-04-29在PHP中通过GD库创建简单的图片(图文详解)
  • 2022-04-29Illustrator绘制水晶质感苹果标志
  • 2022-04-29phpcms后台上传不了图片怎么办
  • 2022-04-29微信小程序实现点赞业务
  • 2022-04-29给DEDECMS后台加上批量修改tags功能
  • 2022-04-29聊聊Bootstrap4中的网格系统
  • 2022-04-29PHP实现姓名根据首字母排序的类与方法(实例代码)
  • 2022-04-29Dedecms5.7如何将系统的data目录迁移到web以外目录
  • 2022-04-29MySQL中 IN和NOT IN用法详解

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • PHP如何使用日期时间类Carbon
    • WordPress纯代码生成文章海报图片实现分享功能
    • php如何生成随机字符串并不重复
    • Photoshop数位板人物设计教程:《主教MM》
    • Photoshop图层样式制作质感光盘包装
    • Thinkphp5分页函数paginate中的each()传入自定义参数
    • 关于ThinkPhp view路径用到的常量 __STATIC__ __JS__ __CSS__等
    • Angular利用service实现自定义服务(notification)
    • 介绍thinkphp5框架中的hook机制
    • 百度统计升级屏蔽黑灰产信息功能

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有