Hyperf2.1版本将查询构造器查询的结果由对象格式转成数组格式

管理员 发布于 3年前   821

官方手册描述:

将结果转为数组格式

在某些场景下,您可能会希望查询出来的结果内采用 数组(Array) 而不是 stdClass 对象结构时,而 Eloquent 又去除了通过配置的形式配置默认的 FetchMode,那么此时可以通过监听器来监听 Hyperf\Database\Events\StatementPrepared 事件来变更该配置


主要的效果就是链式操作get(), first() 等等...直接就是输出数组了 不用在toArray()了


配置步骤


在app/Listener/目录下新建文件 FetchModeListener.php 


<?php
declare(strict_types=1);
namespace App\Listener;
use Hyperf\Database\Events\StatementPrepared;
use Hyperf\Event\Annotation\Listener;
use Hyperf\Event\Contract\ListenerInterface;
use PDO;
/**
 * @Listener
 */
class FetchModeListener implements ListenerInterface
{
    public function listen(): array
    {
        return [
            StatementPrepared::class,
        ];
    }
    public function process(object $event)
    {
        if ($event instanceof StatementPrepared) {
            $event->statement->setFetchMode(PDO::FETCH_ASSOC);
        }
    }
}

在把上面的信息复制上去就ok了


看看效果:

直接在登录接口上测试一下


<?php
declare(strict_types=1);
namespace App\Controller;
use Hyperf\View\RenderInterface;
use Hyperf\DbConnection\Db;
class UserController extends AbstractController
{
    public function login(RenderInterface $render)
    {
        if ($this->request->isMethod('post')) {
            $email = $this->request->input('email');
            $password = md5($this->request->input('password'));
            $res = Db::table('user')->where('email',$email)->where('password',$password)->first();
            return $res;
        }
    }
}

看图

1.png


hyperf手册:https://hyperf.wiki/2.1/#/zh-cn/db/querybuilder

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

该博客于2020-12-7日,后端基于go语言的beego框架开发
前端页面使用Bootstrap可视化布局系统自动生成

是我仿的原来我的TP5框架写的博客,比较粗糙,底下是入口
侯体宗的博客

      订阅博客周刊

文章标签

友情链接

HouTiZong
侯体宗的博客
© 2020 zongscan.com
版权所有ICP证 : 粤ICP备20027696号
PHP交流群
侯体宗的博客