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

发布时间:2023年12月28日

目录

方法一:使用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();

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


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

文章来源:https://blog.csdn.net/q8688/article/details/135272418
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。