찾다
PHP 프레임워크Laravellaravel 합계 다른 조건

laravel 합계 다른 조건

May 26, 2023 pm 01:39 PM

Laravel은 개발 효율성을 향상시키기 위해 다양한 편리한 기능과 구문을 제공하는 인기 있는 PHP 개발 프레임워크입니다. 그 중 sum 함수는 Laravel에서 매우 흔히 사용되는 함수로, 집합의 값을 합할 수 있습니다. 그런데 실제 개발에서는 때로는 다른 조건에서 합산을 수행해야 하는 경우가 있습니다. 이를 어떻게 처리해야 할까요? 이 기사에서는 Laravel이 다양한 조건에서 합계 연산을 수행하는 방법을 소개합니다.

1. 간단한 경우의 합계 연산

Laravel에서는 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.

2. 조건부 합 연산

실제 개발에서는 다양한 조건에서 합 연산을 수행해야 하는 경우가 많습니다. 이 경우 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');

이 예에서 $ 값은 합은 60 , 즉 20+40의 합입니다.

3. 여러 조건에 따른 합산

때로는 여러 조건에 따른 합산 연산을 수행해야 할 때가 있습니다. 이는 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의 값은 Alice의 나이인 20입니다.

마찬가지로 주문 배열이 있는 경우 각 주문에는 상태 속성과 날짜 속성이 있으며, 완료된 모든 주문에서 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 합계 다른 조건의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
포용의 환상 : 원격 작업의 고립과 외로움 해결포용의 환상 : 원격 작업의 고립과 외로움 해결Apr 25, 2025 am 12:28 AM

TocombatisolationandloneLinessInremotwork, componiesshouldimplementregular, meignmentfortuncations, andusetechnologyeftically

풀 스택 개발을위한 Laravel : 포괄적 인 가이드풀 스택 개발을위한 Laravel : 포괄적 인 가이드Apr 25, 2025 am 12:27 AM

laravelispopularforfull-stackdevelopmentBecauseItOffersAMESAMLESSEAMLESTBBOCKENDPOWERANDFRONDENDFLECTION.1) itsBackEndCapabilities, likeeloquentorm, simplifydatabaseintercations.2) theBladetemplatingEngineallowsforclean, dynamichtmltemplates.3) larvelmix

화상 회의 대결 : 원격 회의에 적합한 플랫폼 선택화상 회의 대결 : 원격 회의에 적합한 플랫폼 선택Apr 25, 2025 am 12:26 AM

화상 회의 플랫폼을 선택할 때의 주요 요소에는 사용자 인터페이스, 보안 및 기능이 포함됩니다. 1) 사용자 인터페이스는 줌과 같은 직관적이어야합니다. 2) 보안에주의를 기울여야하며 Microsoft Teams는 엔드 투 엔드 암호화를 제공합니다. 3) 기능은 요구 사항을 일치시키기 위해 필요하며 Googlemeet은 짧은 회의에 적합하며 Ciscowebex는 고급 협업 도구를 제공합니다.

최신 Laravel과 호환되는 데이터베이스 버전은 무엇입니까?최신 Laravel과 호환되는 데이터베이스 버전은 무엇입니까?Apr 25, 2025 am 12:25 AM

Laravel10의 최신 버전은 MySQL 5.7 이상, PostgreSQL 9.6 이상, SQLite 3.8.8 이상, SQLServer 2017 이상과 호환됩니다. 이러한 버전은 JSON 데이터 유형 MySQL5.7과 같은 Laravel의 ORM 기능을 지원하여 쿼리 및 스토리지 효율성을 향상시키기 때문에 선택됩니다.

Laravel을 풀 스택 프레임 워크로 사용하는 이점Laravel을 풀 스택 프레임 워크로 사용하는 이점Apr 25, 2025 am 12:24 AM

laravelisanexcellentchoiceforfull-stackdevelopmentduetoitsrobustfeaturesandeaseofuse.1) 1) itsimplifiescomplextaskswithitsmodernphpsyntaxandtoolslakeforfront-endandeloquentormforback-end.2) laravel'secosystem, entercancesancancesancancessancancesancancesancesancesancancesnan

Laravel의 최신 버전은 무엇입니까?Laravel의 최신 버전은 무엇입니까?Apr 24, 2025 pm 05:17 PM

LARAVEL10, RELEARTESTERSION. ISTHELATESTVERSION. ISTHELATESTERSION.ITFEATURES : 1) 개선 된 오류가 개선 된 사람을 사용하여 개선되었습니다.

최신 Laravel 버전은 개발을 어떻게 단순화합니까?최신 Laravel 버전은 개발을 어떻게 단순화합니까?Apr 24, 2025 pm 05:01 PM

thelatestlaravelversionenhancesdevelopmentwith : 1) simplifiedroutingusingiMplicitModelBinding, 2) enloquentCapabilities withNeweRyMethods, 및 3) 개선 된 개선 된 개선 된 kepportOndHefeatureslikeNameDarguments,

최신 Laravel 버전의 릴리스 노트는 어디에서 찾을 수 있습니까?최신 Laravel 버전의 릴리스 노트는 어디에서 찾을 수 있습니까?Apr 24, 2025 pm 04:53 PM

laravel.com/docs에서 최신 Laravel 버전의 릴리스 노트를 찾을 수 있습니다. 1) 릴리스 노트는 새로운 기능, 버그 수정 및 개선에 대한 자세한 정보를 제공합니다. 2) 새로운 기능의 적용을 이해하는 데 도움이되는 예와 설명이 포함되어 있습니다. 3) 새로운 기능의 잠재적 복잡성과 후진 호환성 문제에주의하십시오. 4) 릴리스 노트를 정기적으로 검토하면 업데이트를 유지하고 혁신을 고무시킬 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구