webard / biloquent
v1.4.0
2024-04-05 17:24 UTC
Requires
- php: ^8.1
- illuminate/contracts: ^10.0|^11.0
- illuminate/database: ^10.0|^11.0
- illuminate/support: ^10.0|^11.0
- staudenmeir/laravel-cte: ^1.9
Requires (Dev)
- larastan/larastan: ^2.0.1
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.8
- orchestra/testbench: ^8.8
- pestphp/pest: ^2.20
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- spatie/laravel-ray: ^1.26
README
对 Eloquent 模型的报告。
该包处于开发阶段,处于非常早期。
UDF 注入
一些聚合器需要UDF 注入扩展以支持 MySQL
- 偏度
- 中位数
- 百分位数
- 偏斜度
示例报告
基于 Order 模型,需要总金额和创建时间字段。
创建文件 App\Reports\OrderReport.php
declare(strict_types=1); namespace App\Reports; use Webard\Biloquent\Aggregators\Avg; use Webard\Biloquent\Aggregators\Count; use Webard\Biloquent\Report; use Illuminate\Database\Eloquent\Relations\BelongsTo; use App\Models\User; use App\Models\Order; class OrderReport extends Report { public static string $model = Order::class; // Defaults if not defined public array $grouping = ['year']; public array $columns = ['total_orders']; // Define needed relations, they are not taken from source model (yet) public function customer(): BelongsTo { return $this->belongsTo(User::class, 'customer_id'); } // Define aggregators public function aggregators(): array { // It is good practice to alias column names, but not necessary return [ 'total_orders' => Count::field('total_orders', 'orders.id'), 'average_amount' => Avg::field('average_amount', 'orders.value'), ]; } public function groups(): array { // It is good practice to alias column names, but not necessary return [ 'day' => [ // aggregator will be applied to report query 'aggregator' => 'DAY(orders_created_at)', // field will be fetched from dataset query 'field' => 'orders.created_at as orders_created_at' ], 'month' => [ 'aggregator' => 'MONTH(orders_created_at)', 'field' => 'orders.created_at as orders_created_at' ], 'year' => [ 'aggregator' => 'YEAR(orders_created_at)', 'field' => 'orders.created_at as orders_created_at' ], 'date' => [ 'aggregator' => 'DATE(orders_created_at)', 'field' => 'orders.created_at as orders_created_at' ], 'channel_id' => [ 'field' => 'channels.channel_id as channels_channel_id', 'aggregator' => 'channels_channel_id' ], ]; } }
现在您可以使用报告
$report = OrderReport::query() // set grouping fields ->grouping(['month', 'year']) // set which data you want to calculate ->summary(['total_orders']) // narrow down dataset that you want to calculate ->enhance(function($model) { $model->whereYear('created_at','>=', '2023'); }) // prepare report (this needs to be called before running query) ->prepare() // get results ->get();
示例输出
[ 0 => [ 'year' => 2023, 'month' => 12, 'total_orders' => 5, ], 1 => [ 'year' => 2024, 'month' => 4, 'total_orders' => 2, ], ]