热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

老司机竟然在判断返回结果上翻车了(ThinkPHP)

“本文属于基础内容,看到的同学检查一下自己的代码有没有出现同样的问题”前言小Q又带着问题来了,今天的问题估计是大多数同志

本文属于基础内容,看到的同学检查一下自己的代码有没有出现同样的问题

前言

小Q又带着问题来了,今天的问题估计是大多数同志都会犯的问题。

问题是在使用ThinkPHP时查询返回的结果判断是否为空。

是不是很自信,这有什么不知道的,不就是empty嘛!如果你是这样认为的,那还是把文章简单的看完哈!

这个问题的缘由就是对框架查询数据库返回的结果是什么类型不明确,知道了类型就是一个非常简单的问题。

一笑泯恩仇
一笑泯恩仇

一、问题重现

数据库很简单就一张表user,这个表中没有任何数据,就是一个空表。

数据库
数据库

然后使用ThinkPHP框架进行查询这个表的数据

查询代码
查询代码

小Q给你三秒钟思考,这里会返回什么值。要么返回暂无数据,要么返回用户表的数据。

小Q毫不思索的说肯定会返回暂无数据,因为user表根本就没有数据。

那么来看一下打印的结果是什么。

小Q睁大了眼睛看也没有看到暂无数据四个字,而是返回了一空数组(暂且这么认为)。

这里是暂时认为这就是一个空数组,其实只是长得像数组罢了,真的数据结构是结果集。至于什么是结果集,就自行百度哈!

返回结果
返回结果

这个时候小Q懵了啊!怎么会这样呢!在小Q强烈的要求下打印了date的数据

希望不是你
希望不是你

返回结果仍然还是一个空数组(暂且这样认为)

返回结果
返回结果

那么判断一个数组是否为空肯定得是empty()来进行判断的,对吧!

小Q自信十足的点了点头,这次肯定没有问题,这种写法我都写了好几年了,就是用empty来进行判断的。

自信的你
自信的你

为了让小Q看见骨灰盒在落泪,咔咔只能在对这个值进行一次是否为空的判断。

代码如下

代码打印
代码打印

小Q脸上洋溢着无比灿烂的笑容,我都不忍心去点击请求按钮。

无奈与小Q的期望,残忍的按下了请求按钮。

返回结果
返回结果

看到了上边的返回结果,小Q脸上的笑容顿时戛然而止,随之迎来的就是满脸质疑的大脸盘子。

疑惑
疑惑

再一次的检查了写的判断代码是否有问题。

老夫纵横沙场几十年,复制粘贴,拿起键盘就是干的实力怎么可能会把这个代码写错。

小Q终于坐不住了,笑嘻嘻的问,这是怎么回事啊!

小Q的笑容
小Q的笑容

终于要来到重点了,请继续看怎么让小Q明白这其中的道理的。

二、解决问题

此刻急需来检测一下返回的这data到底是不是我们坚持认为的数组,接下来检测一下。

于是拿起键盘敲了八下,那就是is_array这个函数。

再一次的发起请求

打印结果
打印结果

此时小Q的表情就是这样的,这下是真的凌乱了

你以前不是这样子的
你以前不是这样子的

于是我不慌不忙的打开官网的文档,给小Q看了一眼

官网明确的说明数据返回的结果就是数据集,而且在5.1的版本是直接默认的。

官网文档
官网文档

再继续往下看,你会看到额外的方法都有什么,第一个认识不,是否为空。

小Q惊呆的说了一句,卧槽,不会是用这种方式进行判断的吧!

额外的方法
额外的方法

是不是检测一下就可以了。

检测代码
检测代码

小Q终于一把鼻涕一把泪的说,我以为我眼睛出问题了呢!

明明是空数据怎么就判断不出来呢!长长的出了一口气。

返回结果
返回结果

小Q一脸迷茫的看了我一眼,说了一句,自从使用了5.1框架后,所有的判断都是这样写的。小Q紧忙的着小跑了出去,只说了一句话,赶紧在线上没有出现问题前把代码修复好,要不我就下岗了。在这里插入图片描述

解决了小Q 的问题, 接下来聊点其它的。

三、扩展

解决了小Q的问题就来聊点正经话题。

在上文中存在一个遗漏问题,那就是empty,在PHP中判断数组是否为空就是使用的empty。

这一点小Q是坚定不移的认为是这个样子的,那么这种用法在框架中还能用吗?

那肯定是没有问题的啊!看下图

代码
代码

返回结果肯定跟预想的是一样的,真理永远都是真理。

返回结果
返回结果

四、总结

送给小Q的总结,精华总是那么的简单。

虽然返回结果可以在数据库的配置文件进行修改,但是咔咔是不建议修改的。

既然框架已经默认为结果集,那就使用结果结果集,如果非要使用数组那也是可以的。

经过小Q的这个问题,需要注意以下几点问题。

  • 使用find查询时,如果结果为空返回结果是null,那么判断可以使用来进行判断
  • 使用select查询时,如果结果为空,返回结果是一个空的结果集,可以使用结果集额外的函数toArray()进行转换为数组,然后使用empty进行判断。然而如果就使用结果集进行判断的话就是$data->isEmpty()提供的函数进行判断即可。

坚持学习、坚持写博、坚持分享是咔咔从业以来一直所秉持的信念。希望在偌大互联网中咔咔的文章能带给你一丝丝帮助。我是咔咔,下期见。


推荐阅读
  • 包含phppdoerrorcode的词条 ... [详细]
  • 本文详细介绍了如何在PHP中记录和管理行为日志,包括ThinkPHP框架中的日志记录方法、日志的用途、实现原理以及相关配置。 ... [详细]
  • 在 Ubuntu 中遇到 Samba 服务器故障时,尝试卸载并重新安装 Samba 发现配置文件未重新生成。本文介绍了解决该问题的方法。 ... [详细]
  • 周排行与月排行榜开发总结
    本文详细介绍了如何在PHP中实现周排行和月排行榜的开发,包括数据库设计、数据记录和查询方法。涉及的知识点包括MySQL的GROUP BY、WEEK和MONTH函数。 ... [详细]
  • ThinkPHP RBAC 实战:登录验证详解
    本文将详细介绍 ThinkPHP 框架中的 RBAC(角色基础访问控制)系统,特别是登录验证部分。我们将通过实际代码示例,展示如何实现用户登录验证、验证码生成及验证、以及登录后的权限管理。 ... [详细]
  • 本文详细介绍了如何解决DNS服务器配置转发无法解析的问题,包括编辑主配置文件和重启域名服务的具体步骤。 ... [详细]
  • 从0到1搭建大数据平台
    从0到1搭建大数据平台 ... [详细]
  • 如何在Java中使用DButils类
    这期内容当中小编将会给大家带来有关如何在Java中使用DButils类,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。D ... [详细]
  • 本文详细介绍了 PHP 中对象的生命周期、内存管理和魔术方法的使用,包括对象的自动销毁、析构函数的作用以及各种魔术方法的具体应用场景。 ... [详细]
  • 浏览器作为我们日常不可或缺的软件工具,其背后的运作机制却鲜为人知。本文将深入探讨浏览器内核及其版本的演变历程,帮助读者更好地理解这一关键技术组件,揭示其内部运作的奥秘。 ... [详细]
  • PHP 各版本对比:标准版与最新顶级版的详细分析 ... [详细]
  • 实现Nginx对ThinkPHP URL重写及PATHINFO支持的详细方法解析【PHP开发】
    在PHP后端开发中,实现Nginx对ThinkPHP的URL重写及PATHINFO支持是一项常见的需求。本文详细解析了经过多次尝试和研究,最终找到的一种有效配置方法,能够确保URL_MODERewrite功能正常运行,并提供稳定的服务。此外,文章还探讨了相关配置项的具体作用及其优化建议,帮助开发者更好地理解和应用这些技术。 ... [详细]
  • 本文介绍了如何使用Flume从Linux文件系统收集日志并存储到HDFS,然后通过MapReduce清洗数据,使用Hive进行数据分析,并最终通过Sqoop将结果导出到MySQL数据库。 ... [详细]
  • 本文详细介绍了MySQL数据库服务器(mysqld)和客户端(mysql)的区别,并提供了多种启动和关闭MySQL服务器的方法。通过这些方法,您可以更好地管理和维护MySQL数据库。 ... [详细]
  • 搜索引擎技术概论(上篇):核心原理与应用分析
    搜索引擎技术概论(上篇)探讨了搜索的基本概念及其核心原理。搜索的本质在于信息检索,即用户通过输入关键词,利用特定的算法从海量数据中快速定位并提供所需信息。本文详细分析了搜索引擎的工作机制及其在实际应用中的表现。 ... [详细]
author-avatar
博文_Andrew-属_394
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有