博客列表 >拓展 laravel DB类转查询结果为纯数组

拓展 laravel DB类转查询结果为纯数组

赵大叔
赵大叔原创
2020年06月11日 16:47:491438浏览

理论基础

  • 1、有(macroable)的类才可以扩展。
  • 2、可以在执行时将其它方法添加到 Collection 类。
  • 3、AppServiceProvider.php中必须要有boot方法。
  • 4、 macro('扩展的方法名称', '该方法执行的操作')参数。

代码

1、在app\providers下创建DBServiceProvider.php

  • 参考AppServiceProvider.php文件内容,可以直接复制修改。
  • 必须要有boot方法
  1. <?php
  2. namespace App\Providers;
  3. use Illuminate\Support\ServiceProvider;
  4. use Illuminate\Database\Query\Builder as QueryBuilder;
  5. class DBServiceProvider extends ServiceProvider
  6. {
  7. public function boot()
  8. {
  9. QueryBuilder::macro('arrlists', function(){
  10. $data = $this->get()->map(function ($value){
  11. return (array)$value;
  12. })->toArray();
  13. return $data;
  14. });
  15. }
  16. }

2、在config\app.php中把DBServiceProvider注册到框架

  • 参考App\Providers\RouteServiceProvider::class,修改。
  1. // 扩展DBServiceProvider
  2. App\Providers\DBServiceProvider::class,

3、使用扩展的方法

  • 和调用get()、all()一样的调用。
  1. DB::table('admin')->arrlists();

查询结果为纯数组:

总结

扩展后查询结果就变为纯数组,方便处理和调用。

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议