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

2022-09-20 14:57:03 浏览数 (1)

文章目录(更新中…)

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 中指定了返回的内容列,那么此时访问后结果如下:

闭包

0 人点赞