返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >04 tp6 的查数据 find、select、findOrEmpty、findOrFail、toArray、selectOrFail、value、column《ThinkPHP6 入门到电商实战》
  • 587
分享到

04 tp6 的查数据 find、select、findOrEmpty、findOrFail、toArray、selectOrFail、value、column《ThinkPHP6 入门到电商实战》

php后端thinkphp 2023-09-17 19:09:37 587人浏览 独家记忆
摘要

文章目录(更新中…) 01 thinkphp6的前期开发准备《ThinkPHP6 入门到电商实战》 02 控制器《ThinkPHP6 入门到电商实战》 03 数据库查询、模型查询、多库查询《Think

文章目录(更新中…)

01 thinkphp6的前期开发准备《ThinkPHP6 入门到电商实战》
02 控制器《ThinkPHP6 入门到电商实战》
03 数据库查询、模型查询、多库查询《ThinkPHP6 入门到电商实战》
04 tp6 的查数据《ThinkPHP6 入门到电商实战》
05 tp6 的数据添加《ThinkPHP6 入门到电商实战》
06 tp6 的数据更新(改)及删除 《ThinkPHP6 入门到电商实战》
07查询表达式 及 page分页、order 排序《ThinkPHP6 入门到电商实战》
08 获取器 withAttr、多连缀、whereRaw、事务、数据集《ThinkPHP6 入门到电商实战》

若是大一学子或者是真心想学习刚入门的小伙伴可以私聊我,若你是真心学习可以送你书籍,指导你学习,给予你目标方向的学习路线,无套路,博客为证。

一、查数据的不同方法

1.1 table 方法 的单条数据查询

table 方法是查询数据的一种方法,在查询时需要指定数据库表名,并且可以指定是查找一条数据还是多条数据。

例如如下方式则是使用table查询一条数据(引用官方手册),其中的-> 所链接的操作被称为链式操作:

// table方法必须指定完整的数据表名Db::table('think_user')->where('id', 1)->find();

1.1.1 table 的 find 操作

以上示例中 think_user 表示当前数据库的表名且表名必须完整,而后面所链接的 where 表示传入一个条件,在此处表示 id 值为 1 的数据,最后的 find 表示执行 find 操作。

此时我们查看数据库中的表:
在这里插入图片描述
在此我们查询一条 id 为 5 的数据,那么代码可以编写为:

Db::table('student')->where('id', 5)->find();

此时在index.PHP 控制器中增加一个 select 方法:

public function select(){    //table find    $res=Db::table('student')->where('id', 5)->find();    dump($res);}

最后使用 dump 输出结果,访问该方法后将会得到 null,当查询为空时则为null:
在这里插入图片描述

1.1.2 find 的 findOrEmpty、findOrFail 操作

若想在查询结果为 null 时返回空数据,那么可以使用 findOrEmpty 进行查询,例如如下代码:

public function select(){     $res=Db::table('student')->where('id', 6)->findOrEmpty();     dump($res); }

此时访问后结果如下:
在这里插入图片描述

若想在查询为空时返回异常,那么直接使用 findOrFail 查询即可:

public function select(){    $res=Db::table('student')->where('id', 6)->findOrFail();    dump($res);}

此时访问后结果如下:
在这里插入图片描述

1.2 table 方法 的多条数据查询

在 1.1 中的示例均是单条数据查询,在这里咱们开始介绍多少数据的查询方式。

1.2.1 table 的 select 操作

在之前使用了find 查询单条数据,在这里咱们使用 select 查询多条数据,示例如下(示例来源官方手册):

Db::table('think_user')->where('status', 1)->select();

若此时我们需要查询数据表中身高为 170 的学生,那么此时表如下:
在这里插入图片描述
查询代码即可写成:

Db::table('student')->where('height', 170)->select();

那么此时 select 方法可以修改成:

public function select(){    $res=Db::table('student')->where('height', 170)->select();    dump($res);}

此时结果如下:
在这里插入图片描述
由于此时所查询的是数据集,并不是单挑数据,所以此时的结果为多条数据。

1.2.2 select 的 selectOrFail、toArray 操作

find 有 finOrFail 操作,那么同样的 select 也有此操作,当查询数据集时若返回为空想要抛出异常,那么就使用 selectOrFail,此时代码如下:

$res=Db::table('student')->where('height', 170)->selectOrFail();

过多举例不做演示了,因为效果跟 find 的对应方法类似,此时演示 toArray 方法;toArray 方法表示将数据集转换为数组。有些同学可能疑惑,本身查询到的数据不是数组嘛?其实本身查询到的数据并不是数组,而是 Collection :

在这里插入图片描述
此时转为数组直接使用 toArray方法即可:

$res=Db::table('student')->where('height', 170)->select()->toArray();

结果如下:

在这里插入图片描述

1.3 value 指定返回值

在查询一条数据时,可以使用 value 指定返回值内容,例如如下代码:

public function select(){   $res=Db::table('student')->where('id', 5)->value('name');   dump($res);}

其中 value 表示指定返回值的内容,那么此时查询到数据后,返回结果如下:
在这里插入图片描述
若数据为空则返回 null:

在这里插入图片描述

1.3 column 指定返回值

在单条数据时我们可以使用 value 返回指定内容,但是在多条数据时怎么办呢?此时可以使用 column 指定多条数据返回值的内容,例如如下代码:

public function select(){   $res=Db::table('student')->where('height', 170)->column('name','nickname');   dump($res);}

此时再 column 中指定了返回的内容列,那么此时访问后结果如下:
在这里插入图片描述

闭包

来源地址:https://blog.csdn.net/A757291228/article/details/126180403

--结束END--

本文标题: 04 tp6 的查数据 find、select、findOrEmpty、findOrFail、toArray、selectOrFail、value、column《ThinkPHP6 入门到电商实战》

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

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

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作