拓展 laravel DB类转查询结果为纯数组
程序员文章站
2022-03-27 08:26:08
...
理论基础
- 1、有
(macroable)
的类才可以扩展。 - 2、可以在执行时将其它方法添加到 Collection 类。
- 3、
AppServiceProvider.php
中必须要有boot
方法。 - 4、
macro('扩展的方法名称', '该方法执行的操作')
参数。
代码
1、在app\providers
下创建DBServiceProvider.php
- 参考
AppServiceProvider.php
文件内容,可以直接复制修改。 -
必须要有boot方法
。
<?php
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
use Illuminate\Database\Query\Builder as QueryBuilder;
class DBServiceProvider extends ServiceProvider
{
public function boot()
{
QueryBuilder::macro('arrlists', function(){
$data = $this->get()->map(function ($value){
return (array)$value;
})->toArray();
return $data;
});
}
}
2、在config\app.php
中把DBServiceProvider
注册到框架
- 参考
App\Providers\RouteServiceProvider::class,
修改。
// 扩展DBServiceProvider
App\Providers\DBServiceProvider::class,
3、使用扩展的方法
- 和调用
get()、all()
一样的调用。
DB::table('admin')->arrlists();
查询结果为纯数组:
总结
扩展后查询结果就变为纯数组,方便处理和调用。
上一篇: 微信5秒内没反应断开连接怎么处理?
下一篇: 如果把变量作为常量的名称?