当前位置: 首页 > news >正文

【PHP】TP5.0及Fastadmin中将查询数据返回对象转为数组

目录

方法一:使用collection助手函数

方法二:设置返回数据集的对象名


在 ThinkPHP 5.0 中,对模型查询返回的对象进行了优化,默认情况下,使用 all 或 select 方法查询数据库将返回一个对象数组集合。这个集合是模型的实例数组,不是传统意义上的数组。因此,直接调用 toArray 方法并不能将其转换为真正的多维数组


为了帮助开发者更好地理解和使用对象集合,以下是一些指导建议:

  1. 理解对象数组: 首先,应当理解在 ThinkPHP 中,all 和 select 返回的对象数组实际上是模型的集合,每个元素都是一个模型实例,拥有模型的属性和方法。
  2. 使用对象: 开发者应当尽量利用对象的优势,比如可以直接访问对象的属性和方法,进行链式调用等。
  3. 转换为数组: 如果确实需要将对象数组转换为传统数组,可以通过设置模型属性 resultSetType 来指定返回的数据结构,或者使用 collection 辅助函数结合 toArray 方法来实现。

方法一:使用collection助手函数


示例代码如下:

$list = User::all();
if($list) {$list = collection($list)->toArray();
}$list = User::where('status', 'normal')->select();
if($list) {$list = collection($list)->toArray();
}

方法二:设置返回数据集的对象名


示例代码如下:

// 在模型里写
namespace app\admin\model;class user extends Model
{protected $resultSetType = 'collection';}// 控制器
$result = User::order("id desc")->select()->toArray();

注意:如果是find或者get查询


此时不可以使用collection

示例:

$user = USER::get(1);
//此时$user是object
$user = USER::get(1)->toarray();
//此时$user是array 一位数字组

 

注意: 在使用 all 或 select 时,返回的结果已经是模型的集合,所以直接调用 toArray 并不会得到预期的结果。只有将模型集合转换为数组集合之后,才能对其进行传统数组的操作。


为了提高代码的可读性和性能,建议在可能的情况下,优先使用对象集合,而不是频繁地进行数组转换。希望这些建议能够帮助开发者更好地理解和使用 ThinkPHP 5.0 中的模型查询。

http://www.lryc.cn/news/272926.html

相关文章:

  • 大公司里怎样开发和部署前端代码?
  • API接口:原理、设计与实践
  • 2023年TIOBE指数TOP50的编程语言写“Hello World!”
  • spring、springmvc、springboot、springcloud简介
  • 立仪科技光谱共焦位移传感器:应用领域的广泛性
  • neo4j图数据库安装和测试
  • 爬取豆瓣电影top250的电影名称(完整代码与解释)
  • tidb 集成 flyway 报错 denied to user for table global_variables
  • 很实用的ChatGPT网站—在线编程模块增补篇
  • A股风格因子看板 (2024.01第01期)
  • 基于gamma矫正的照片亮度调整(python和opencv实现)
  • LeetCode-Java(29)
  • 腾讯云导入导出镜像官方文档
  • keras 深度学习框架实现 手写数字识别
  • SELinux策略语法以及示例策略
  • 电路笔记 :自激振荡电路笔记 电弧打火机
  • prometheus grafana linux服务器监控
  • 有哪些有用的工作技巧?
  • k8s的网络类型
  • 《元宇宙2086》团队发布AI创作的元宇宙之歌
  • 【数据结构】数组实现队列(详细版)
  • Sharding-JDBC快速使用【笔记】
  • 总结MySQL 的一些知识点:MySQL 排序
  • Linux中经常使用的相关命令
  • 2022-2023年度广东省职业院校学生专业技能大赛“软件测试”赛项性能测试题目-Jmeter
  • R304S 指纹识别模块的硬件接口说明
  • postman使用-05新建测试集
  • oracle 子查询和窗口函数
  • 数据库开发与设计过程中的问题分析总结
  • 《数据库开发实践》之存储过程【知识点罗列+例题演练】