【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 中的模型查询。

最近更新

  1. TCP协议是安全的吗?

    2023-12-29 19:16:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-29 19:16:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-29 19:16:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-29 19:16:02       20 阅读

热门阅读

  1. Qt/QML编程学习之心得:loader和component(二十)

    2023-12-29 19:16:02       41 阅读
  2. Unity Timer两种计时器

    2023-12-29 19:16:02       30 阅读
  3. android RecyclerView1.3.2与NestedScrollingParent的变化

    2023-12-29 19:16:02       41 阅读
  4. AI训练师常用的ChatGPT通用提示词模板

    2023-12-29 19:16:02       37 阅读
  5. js中三种URI编码方式比较

    2023-12-29 19:16:02       39 阅读
  6. GO语言工具函数库--Lancet

    2023-12-29 19:16:02       35 阅读
  7. php5.6安装mongo扩展

    2023-12-29 19:16:02       42 阅读
  8. 使用conda在Windows上建立虚拟环境

    2023-12-29 19:16:02       40 阅读
  9. 分享一波测试面试题(偏银行、信贷)

    2023-12-29 19:16:02       33 阅读
  10. 信息安全管理实践

    2023-12-29 19:16:02       41 阅读