目录
在 ThinkPHP 5.0 中,对模型查询返回的对象进行了优化,默认情况下,使用 all 或 select 方法查询数据库将返回一个对象数组集合。这个集合是模型的实例数组,不是传统意义上的数组。因此,直接调用 toArray 方法并不能将其转换为真正的多维数组。
为了帮助开发者更好地理解和使用对象集合,以下是一些指导建议:
示例代码如下:
$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 中的模型查询。