Hyperf2.1版本将查询构造器查询的结果由对象格式转成数组格式
官方手册描述:
将结果转为数组格式
在某些场景下,您可能会希望查询出来的结果内采用 数组(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;
}
}
}
看图
hyperf手册:https://hyperf.wiki/2.1/#/zh-cn/db/querybuilder
相关文章