Laravel 查询构造器如何实现批量处理数据集合类似 ThinkPHP 中 withAttr 功能的效果?
时间:2024-12-6 21:03 作者:emer 分类: 无

查询构造器中批量处理数据集合
在laravel中,可以通过修改内置的toarray方法或自己实现一个新方法,实现类似于中withattr功能的效果。
自定义方法
namespace app {
...
class customcollection extends collection
{
// ...其他方法
public function toarray(callable $callback = null)
{
$toarray = $this->items;
if ($callback !== null) {
$toarray = array_map($callback, $toarray);
}
// ...其他逻辑
return $toarray;
}
}
} 登录后复制
然后在查询构造器中使用自定义方法:
立即学习“”;
$orders = db::table('orders')
->select('*')
->toarray(function ($order) {
$order['status'] = ['待付款', '待发货'][$order['status']];
return $order;
}); 登录后复制
修改toarray方法
另一种方法是直接修改toarray方法:
use illuminatesupportcollection;
collection::macro('customtoarray', function () {
$toarray = $this->items;
foreach ($toarray as &$order) {
$order['status'] = ['待付款', '待发货'][$order['status']];
}
// ...其他逻辑
return $toarray;
}); 登录后复制
然后在查询构造器中使用:
$orders = DB::table('orders')
->select('*')
->customToArray(); 登录后复制
以上就是Laravel 查询构造器如何实现批量处理数据集合类似 ThinkPHP 中 withAttr 功能的效果?的详细内容,!