Hyperf2.1版本将查询构造器查询的结果由对象格式转成数组格式
swoole  /  管理员 发布于 3年前   3155
官方手册描述:
将结果转为数组格式
在某些场景下,您可能会希望查询出来的结果内采用 数组(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
123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号