【PHP】TP5.0及Fastadmin中将查询数据返回对象转为数组
2023-12-28 19:55:44
目录
在 ThinkPHP 5.0 中,对模型查询返回的对象进行了优化,默认情况下,使用 all 或 select 方法查询数据库将返回一个对象数组集合。这个集合是模型的实例数组,不是传统意义上的数组。因此,直接调用 toArray 方法并不能将其转换为真正的多维数组。
为了帮助开发者更好地理解和使用对象集合,以下是一些指导建议:
- 理解对象数组: 首先,应当理解在 ThinkPHP 中,all 和 select 返回的对象数组实际上是模型的集合,每个元素都是一个模型实例,拥有模型的属性和方法。
- 使用对象: 开发者应当尽量利用对象的优势,比如可以直接访问对象的属性和方法,进行链式调用等。
- 转换为数组: 如果确实需要将对象数组转换为传统数组,可以通过设置模型属性 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
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!