0

0

Laravel 中统计用户所属业务下缺货商品总数及总采购价

碧海醫心

碧海醫心

发布时间:2025-12-26 16:46:02

|

890人浏览过

|

来源于php中文网

原创

Laravel 中统计用户所属业务下缺货商品总数及总采购价

本文介绍如何在 laravel 中通过 eloquent 或查询构造器,统计指定用户所创建业务下的缺货商品(库存为 0)总数及其采购价总和。

在实际库存管理系统中,常需快速识别“缺货商品”(即 quantity_in_stock = 0)并汇总其采购成本,辅助采购决策或库存预警。结合你提供的 items 表结构,关键字段包括:price(采购单价)、quantity_in_stock、business_id(关联企业),且业务与用户通过 businesses 表关联(假设 users ↔ businesses 为一对多关系)。

⚠️ 注意:原答案中存在两处关键错误,需立即修正:表名拼写错误:'itmes' → 应为 'items';SQL 字符串拼接错误:sum('price') 中的单引号会导致 SQL 解析为字符串字面量,正确写法是 sum(price)(无引号)或使用 DB::raw('SUM(price)')。

✅ 推荐使用 Eloquent 关系链式查询,兼顾可读性、安全性和可维护性:

// 假设已定义模型:User → hasMany Business → hasMany Item
$user = auth()->user(); // 或通过参数获取指定用户

$totalOutOfStock = $user->businesses()
    ->withCount(['items as out_of_stock_count' => function ($query) {
        $query->where('quantity_in_stock', 0);
    }])
    ->withSum(['items as out_of_stock_total_price' => function ($query) {
        $query->where('quantity_in_stock', 0);
    }], 'price')
    ->get()
    ->map(function ($business) {
        return [
            'business_id' => $business->id,
            'out_of_stock_count' => $business->out_of_stock_count,
            'out_of_stock_total_price' => (float) $business->out_of_stock_total_price,
        ];
    });

// 若只需全局聚合(所有业务合计):
$summary = $user->businesses()
    ->join('items', 'businesses.id', '=', 'items.business_id')
    ->where('items.quantity_in_stock', 0)
    ->selectRaw('COUNT(*) as total_items, SUM(items.price) as total_price')
    ->first();

若偏好原始查询构造器(如需极致性能或复杂条件),请使用以下修正后代码

AITDK
AITDK

免费AI SEO工具,SEO的AI生成器

下载
use Illuminate\Support\Facades\DB;

$result = DB::table('items') // ✅ 修正表名
    ->select(
        'business_id',
        DB::raw('COUNT(*) as total_number'),
        DB::raw('SUM(price) as total_price') // ✅ 移除单引号,确保列名解析
    )
    ->where('quantity_in_stock', 0)
    ->groupBy('business_id')
    ->get();

? 额外建议

  • 为提升查询性能,在 items(quantity_in_stock, business_id) 上添加复合索引:
    Schema::table('items', function (Blueprint $table) {
        $table->index(['quantity_in_stock', 'business_id']);
    });
  • 对于 price 和 selling_price 字段,推荐改用 decimal(10,2) 替代 float,避免浮点数精度问题(如 0.1 + 0.2 ≠ 0.3);
  • 在 API 响应中,建议对 total_price 显式格式化为两位小数:number_format($item->total_price, 2)。

通过上述方式,你不仅能准确获取每个业务的缺货统计,还可灵活扩展为按时间范围、品类等维度聚合,真正构建健壮的库存分析能力。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

313

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

270

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

362

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

362

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

80

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

62

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

62

2025.08.05

数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

673

2023.10.12

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号