QB 返回的数据格式

2024-03-23 16:04
文章标签 数据格式 返回 qb

本文主要是介绍QB 返回的数据格式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

想要的效果:

 

而不是  $a['pm] = ['pm' ,'cover','power'] 这种形式.

对应的方法! 

  public function withAttr($name, callable $callback = null){if (is_array($name)) {foreach ($name as $key => $val) {$this->withAttr($key, $val);}return $this;}$this->options['with_attr'][$name] = $callback;if (strpos($name, '.')) {[$relation, $field] = explode('.', $name);if (!empty($this->options['json']) && in_array($relation, $this->options['json'])) {} else {$this->options['with_relation_attr'][$relation][$field] = $callback;unset($this->options['with_attr'][$name]);}}return $this;}

    public function append(array $append = []){$this->options['append'] = $append;return $this;}

    public function page(): array{$builder = new Builder($this->getModel());$builder->setOp(['create_time' => 'DATE_RANGE']);return $builder->selectQuery(function (BaseQuery $query) {//关联查询-开始$query->append(['pm','power','cover'])->withAttr(['pm' => function ($v, $r) {//获取榜单排名$tx = [];$data = (new RechargeModel())->with(['user'])->where('list_id',$r['id'])->field('user_id,SUM(money) as money')->group('user_id')->order('money','desc')->limit(4)->select()->toArray();if(count($data)){foreach ($data as $item){$tx[]= $item['user'];}}return $tx;},'power' => function ($v, $r) {$cover = (new  InfoModel())->where('id',$r['id'])->find();$power =  (new TypeModel())->where('id',$cover['lx'])->find();return $power['power'];},'cover' => function ($v, $r) {$cover = (new  InfoModel())->where('id',$r['id'])->find();return $cover['cover'];},]);$with = array_merge($with ?? [], ['user', 'info', 'plan']);  $query->with($with);//关联查询-结束})->page();}}

这篇关于QB 返回的数据格式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/838841

相关文章

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

C# WebAPI的几种返回类型方式

《C#WebAPI的几种返回类型方式》本文主要介绍了C#WebAPI的几种返回类型方式,包括直接返回指定类型、返回IActionResult实例和返回ActionResult,文中通过示例代码介绍的... 目录创建 Controller 和 Model 类在 Action 中返回 指定类型在 Action

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

Python函数返回多个值的多种方法小结

《Python函数返回多个值的多种方法小结》在Python中,函数通常用于封装一段代码,使其可以重复调用,有时,我们希望一个函数能够返回多个值,Python提供了几种不同的方法来实现这一点,需要的朋友... 目录一、使用元组(Tuple):二、使用列表(list)三、使用字典(Dictionary)四、 使

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n