前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >04 tp6 的查数据 find、select、findOrEmpty、findOrFail、toArray、selectOrFail、value、column《ThinkPHP6 入门到电商实战》

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

作者头像
1_bit
发布2022-09-20 14:57:03
1.2K0
发布2022-09-20 14:57:03
举报
文章被收录于专栏:我的知识小屋
文章目录(更新中…)

01 thinkphp6的前期开发准备《ThinkPHP6 入门到电商实战》 02 控制器《ThinkPHP6 入门到电商实战》 03 数据库查询、模型查询、多库查询《ThinkPHP6 入门到电商实战》 04 tp6 的查数据《ThinkPHP6 入门到电商实战》 05 tp6 的数据添加《ThinkPHP6 入门到电商实战》

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

一、查数据的不同方法

1.1 table 方法 的单条数据查询

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

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

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

1.1.1 table 的 find 操作

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

此时我们查看数据库中的表:

在这里插入图片描述
在这里插入图片描述

在此我们查询一条 id 为 5 的数据,那么代码可以编写为:

代码语言:javascript
复制
Db::table('student')->where('id', 5)->find();

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

代码语言:javascript
复制
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 进行查询,例如如下代码:

代码语言:javascript
复制
public function select(){
     $res=Db::table('student')->where('id', 6)->findOrEmpty();
     dump($res);
 }

此时访问后结果如下:

在这里插入图片描述
在这里插入图片描述

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

代码语言:javascript
复制
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 查询多条数据,示例如下(示例来源官方手册):

代码语言:javascript
复制
Db::table('think_user')->where('status', 1)->select();

若此时我们需要查询数据表中身高为 170 的学生,那么此时表如下:

在这里插入图片描述
在这里插入图片描述

查询代码即可写成:

代码语言:javascript
复制
Db::table('student')->where('height', 170)->select();

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

代码语言:javascript
复制
public function select(){
    $res=Db::table('student')->where('height', 170)->select();
    dump($res);
}

此时结果如下:

在这里插入图片描述
在这里插入图片描述

由于此时所查询的是数据集,并不是单挑数据,所以此时的结果为多条数据。

1.2.2 select 的 selectOrFail、toArray 操作

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

代码语言:javascript
复制
$res=Db::table('student')->where('height', 170)->selectOrFail();

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

在这里插入图片描述
在这里插入图片描述

此时转为数组直接使用 toArray方法即可:

代码语言:javascript
复制
$res=Db::table('student')->where('height', 170)->select()->toArray();

结果如下:

在这里插入图片描述
在这里插入图片描述

1.3 value 指定返回值

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

代码语言:javascript
复制
public function select(){
   $res=Db::table('student')->where('id', 5)->value('name');
   dump($res);
}

其中 value 表示指定返回值的内容,那么此时查询到数据后,返回结果如下:

在这里插入图片描述
在这里插入图片描述

若数据为空则返回 null:

在这里插入图片描述
在这里插入图片描述

1.3 column 指定返回值

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

代码语言:javascript
复制
public function select(){
   $res=Db::table('student')->where('height', 170)->column('name','nickname');
   dump($res);
}

此时再 column 中指定了返回的内容列,那么此时访问后结果如下:

在这里插入图片描述
在这里插入图片描述

闭包

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-08-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、查数据的不同方法
    • 1.1 table 方法 的单条数据查询
      • 1.1.1 table 的 find 操作
      • 1.1.2 find 的 findOrEmpty、findOrFail 操作
    • 1.2 table 方法 的多条数据查询
      • 1.2.1 table 的 select 操作
      • 1.2.2 select 的 selectOrFail、toArray 操作
    • 1.3 value 指定返回值
      • 1.3 column 指定返回值
      • 闭包
      相关产品与服务
      数据库
      云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档