

























2020-09-21 15:15 斌哥tobin 阅读(807) 评论() 收藏 举报
PHP Laravel框架支持Model查询数据后可以有多种方式返回数据,对新手会造成一些困扰,比如数组Model对象、集合、纯数组
今天从内存占用的角度对比一下3种数据返回方式
TestModel::query()->where('field_name', $value)->limit(10)->get()->all();
TestModel::query()->where('field_name', $value)->limit(10)->get();
TestModel::query()->where('field_name', $value)->limit(10)->get()->toArray();
PHP 7.2.28, Docker Compose, MacOS
| 返回格式 | 查询行数 | 查询结果内存占用 |
|---|---|---|
| Model数组 | 10 | 433.2109K |
| array | 10 | 457.5313K |
| Collection | 10 | 433.2891K |
| Model数组 | 100 | 803.3984K |
| array | 100 | 816.4688K |
| Collection | 100 | 803.4766K |
| Model数组 | 1000 | 4.3761M |
| array | 1000 | 4.2790M |
| Collection | 1000 | 4.3762M |
| Model数组 | 10000 | 40.4700M |
| array | 10000 | 39.2743M |
| Collection | 10000 | 40.4701M |
从开发效率和维护角度我建议选择Model数组的开发方式
因为在PhpStorm这个IDE中,Model的查询方法中加入注释 @return static[] 就可以有IDE字段辅助
当然前提是在相应Model的注释中加入属性注释 @property,下方给出几个示例
/**
* @property int $id 主键ID
* @property string $order_sn 订单号
*/
class OrderInfoModel extends Model
{
protected $table = 'order_info';
public $timestamps = false;
/**
单例入口
*/
public static function singleton()
{
return app(static::class);
}
/**
* 查找订单
* @param string $sn
* @return static
*/
public function findBySn($sn)
{
return static::query()->where('order_sn', $sn)->first();
}
/**
* 查找订单列表
* @return static[]
*/
public function findListByPage($page, $pageSize)
{
return static::query()->forPage($page, $pageSize)->get()->all();
}
}
//注意两个方法的 @return 差别
class OrderController extends Controller
{
public function actionList(Request $request)
{
$page = $request->get('page', 1);
$pageSize = $request->get('size', 10);
$results = [];
$list = OrderInfoModel::singleton()->findListByPage($page, $pageSize);
if ($list) foreach ($list as $item) {
$results[] = ['order_sn' => $item->order_sn]; //在IDE中, 这个$item->order_sn是有辅助提示的,就是Model中的@property起的作用
}
//其他代码省略
}
}
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。