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 功能的效果?的详细内容,!