首页 php框架 Laravel laravel sum 不同条件

laravel sum 不同条件

May 26, 2023 pm 01:39 PM

Laravel是一种流行的PHP开发框架,它提供了许多方便的函数和语法来提高开发效率。其中,sum函数是在Laravel中非常常用的一个函数,可以对一个集合中的值进行求和操作。但是在实际开发中,我们有时需要在不同的条件下进行求和,这时该如何应对呢?本文将介绍Laravel如何在不同条件下进行sum求和操作。

一、简单情况下的sum操作

在Laravel中,我们可以很方便地对一个集合进行sum操作,只需调用sum函数即可。例如,对一个数组进行求和:

$sum = collect([1, 2, 3, 4, 5])->sum();
登录后复制

这个例子中,$sum的值为15,即1+2+3+4+5的和。

类似地,如果我们有一个对象数组,想要对其中的某个属性进行求和,可以这样操作:

$sum = collect([
    ['name' => 'Alice', 'score' => 80],
    ['name' => 'Bob', 'score' => 90],
    ['name' => 'Charlie', 'score' => 70]
])->sum('score');
登录后复制

这个例子中,$sum的值为240,即80+90+70的和。

二、条件求和操作

在实际开发中,我们经常需要在不同的条件下进行sum操作,这时就需要用到Laravel中的where函数。where函数可以根据指定的条件过滤集合中的值。例如,我们有一个用户数组,每个用户都有姓名和年龄两个属性,想要计算所有年龄大于18岁的用户年龄之和,可以这样操作:

$users = collect([
    ['name' => 'Alice', 'age' => 20],
    ['name' => 'Bob', 'age' => 16],
    ['name' => 'Charlie', 'age' => 25]
]);

$sum = $user->where('age', '>', 18)->sum('age');
登录后复制

这个例子中,$sum的值为45,即20+25的和。

类似地,如果我们有一个订单数组,每个订单都有一个状态属性,想要计算所有已完成订单的金额之和,可以这样操作:

$orders = collect([
    ['id' => 1, 'status' => 'created', 'amount' => 10],
    ['id' => 2, 'status' => 'completed', 'amount' => 20],
    ['id' => 3, 'status' => 'cancelled', 'amount' => 30],
    ['id' => 4, 'status' => 'completed', 'amount' => 40]
]);

$sum = $orders->where('status', 'completed')->sum('amount');
登录后复制

这个例子中,$sum的值为60,即20+40的和。

三、根据多个条件求和

有时候,我们需要根据多个条件进行sum操作。这时可以使用Laravel中的where函数的链式调用来实现。例如,我们有一个用户数组,每个用户都有姓名、年龄、地区三个属性,想要计算所有地区为北京、年龄大于18岁的用户年龄之和,可以这样操作:

$users = collect([
    ['name' => 'Alice', 'age' => 20, 'area' => 'Beijing'],
    ['name' => 'Bob', 'age' => 16, 'area' => 'Shanghai'],
    ['name' => 'Charlie', 'age' => 25, 'area' => 'Beijing']
]);

$sum = $user->where('age', '>', 18)->where('area', 'Beijing')->sum('age');
登录后复制

这个例子中,$sum的值为20,即Alice的年龄。

类似地,如果我们有一个订单数组,每个订单都有一个状态属性和一个日期属性,想要计算所有已完成订单中2019年1月1日之后的订单金额之和,可以这样操作:

$orders = collect([
    ['id' => 1, 'status' => 'created', 'amount' => 10, 'date' => '2019-01-01'],
    ['id' => 2, 'status' => 'completed', 'amount' => 20, 'date' => '2019-01-05'],
    ['id' => 3, 'status' => 'cancelled', 'amount' => 30, 'date' => '2018-12-31'],
    ['id' => 4, 'status' => 'completed', 'amount' => 40, 'date' => '2019-02-01']
]);

$sum = $orders->where('status', 'completed')->where('date', '>', '2019-01-01')->sum('amount');
登录后复制

这个例子中,$sum的值为20,即第二个订单的金额。

综上所述,Laravel的sum函数和where函数非常方便实用,可以帮助我们快速地完成条件求和操作。在实际开发中,我们可以根据不同的需求灵活运用这些函数,提高开发效率。

以上是laravel sum 不同条件的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

两个点博物馆:邦格荒地地点指南
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

两个点博物馆:邦格荒地地点指南
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

laravel框架安装最新方法 laravel框架安装最新方法 Mar 06, 2025 pm 01:59 PM

laravel框架安装最新方法

laravel-admin菜单管理 laravel-admin菜单管理 Mar 06, 2025 pm 02:02 PM

laravel-admin菜单管理

laravel使用什么版本最好 laravel使用什么版本最好 Mar 06, 2025 pm 01:58 PM

laravel使用什么版本最好

如何在Laravel中构建具有高级功能的宁静API? 如何在Laravel中构建具有高级功能的宁静API? Mar 11, 2025 pm 04:13 PM

如何在Laravel中构建具有高级功能的宁静API?

在云原生环境中使用Laravel的最佳实践是什么? 在云原生环境中使用Laravel的最佳实践是什么? Mar 14, 2025 pm 01:44 PM

在云原生环境中使用Laravel的最佳实践是什么?

Laravel与其他PHP框架(Symfony,Codeigniter,YII)相比如何? Laravel与其他PHP框架(Symfony,Codeigniter,YII)相比如何? Mar 14, 2025 pm 01:49 PM

Laravel与其他PHP框架(Symfony,Codeigniter,YII)相比如何?

如何在Laravel中实施OAuth2身份验证和授权? 如何在Laravel中实施OAuth2身份验证和授权? Mar 12, 2025 pm 05:56 PM

如何在Laravel中实施OAuth2身份验证和授权?

如何在Laravel中创建和使用自定义刀片指令? 如何在Laravel中创建和使用自定义刀片指令? Mar 17, 2025 pm 02:50 PM

如何在Laravel中创建和使用自定义刀片指令?

See all articles