热门标签 | 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()提供的函数进行判断即可。

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


推荐阅读
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • php 获取无限子文件,php快速无限遍历递归文件夹目录、子文件,支持绝对路径和相对路径,支持返回生成数组...
    支持无限极遍历子文件及文件夹,支持绝对路径和相对路径!函数说明:arrayglob(string$pattern[,int$flags]) ... [详细]
  • ThinkPHP6 核心分析:系统服务
    什么是系统服务?系统服务是对于程序要用到的类在使用前先进行类的标识的绑定,以便容器能够对其进行解析(通过服务类的 register 方法),还有就是初始化一些参数、注册路由等(不限 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • 本文介绍了Linux Shell中括号和整数扩展的使用方法,包括命令组、命令替换、初始化数组以及算术表达式和逻辑判断的相关内容。括号中的命令将会在新开的子shell中顺序执行,括号中的变量不能被脚本余下的部分使用。命令替换可以用于将命令的标准输出作为另一个命令的输入。括号中的运算符和表达式符合C语言运算规则,可以用在整数扩展中进行算术计算和逻辑判断。 ... [详细]
  • 8PHP代码审计——thinkphp3.2.3框架信息泄露
    环境:thinkphp_3.2.3_fullphp5.6.27以上下载thinkphp3.2.2解压到http:www.tptest.com网站的根目录下并访问网址& ... [详细]
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社区 版权所有