> 백엔드 개발 > PHP 튜토리얼 > PHP+MySQL 타이밍 데이터 통계 최적화

PHP+MySQL 타이밍 데이터 통계 최적화

php中世界最好的语言
풀어 주다: 2023-03-22 07:28:01
원래의
2326명이 탐색했습니다.

이번에는 PHP+MySQL 타이밍 데이터 통계 최적화에 대해 소개해 드리겠습니다. PHP+MySQL 타이밍 데이터 통계 최적화에 대한 주의사항은 무엇인가요?

인터넷 프로젝트에서는 프로젝트에 대한 데이터 분석이 필수적입니다. 일반적으로 일정 기간 동안의 일일 총 데이터 변화 추세를 계산하여 마케팅 전략을 조정합니다. 다음 사례를 살펴보겠습니다.

사례

일반적으로 전자상거래 플랫폼에는 모든 주문 정보를 기록하는 주문 양식이 있습니다. 이제 데이터 분석을 위해 다음과 같은 통계 차트를 그리기 위해 특정 달의 일별 주문 건수와 판매량을 계산해야 합니다.

주문 테이블의 데이터 구조는 다음과 같습니다.

order_id order_sn total_price enterdate
25396 A4E610E250C2D378D7EC94179E14617F 2306.00 2017-04-01 17:23:26
2539 7 EAD217C0533455EECDDE39659ABCDAE9 17.90 2017-04-01 22:15:18
25398 032E6941DAD44F29651B53C41F6B48A0 163.03 2017-04-02 07:24:36

일별 주문 건수 조회 해당 달의 총액은 어떻게 계산해야 하나요?

일반적인 방법

먼저 생각하기 가장 쉬운 방법은 PHP 함수 <a href="http://www.php.cn/wiki/1230.html" target="을 사용하는 것입니다. _blank">cal_days_in_month<code><a href="http://www.php.cn/wiki/1230.html" target="_blank">cal_days_in_month</a>() 获取当月天数,然后构造一个当月所有天的数组,然后在循环中查询每天的总数,构造新数组。

代码如下:

$month = '04';
$year = '2017';
$max_day = cal_days_in_month(CAL_GREGORIAN, $month, $year);   //当月最后一天
//构造每天的数组
$days_arr = array();
for($i=1;$i<=$max_day;$i++){
  array_push($days_arr, $i);
}
$return = array();
//查询
foreach ($days_arr as $val){
  $min = $year.&#39;-&#39;.$month.&#39;-&#39;.$val.&#39; 00:00:00&#39;;
  $max = $year.&#39;-&#39;.$month.&#39;-&#39;.$val.&#39; 23:59:59&#39;;
  $sql = "select count(*) as total_num,sum(`total_price`) as amount from `orders` where `enterdate` >= {$min} and `enterdate` <= {$max}";
  $return[] = mysqli_query($sql);
}
return $return;
로그인 후 복사

这个sql简单,但是每次需要进行30次查询请,严重拖慢响应时间。

优化

如何使用一个sql直接查询出各天的数量总计呢?

此时需要利用 mysql 的 date_format 函数,在子查询中先查出当月所有订单,并将 enterdate 用 date_format 函数转换为 天 ,然后按天 group by() 해당 월의 일수를 가져온 다음 해당 월의 모든 날짜로 구성된 배열을 구성한 다음 루프에서 각 날짜의 총 수를 쿼리하고 새 배열을 구성합니다.

코드는 다음과 같습니다.

$month = '04';
$year = '2017';
$max_day = cal_days_in_month(CAL_GREGORIAN, $month, $year);   //当月最后一天
$min = $year.'-'.$month.'-01 00:00:00';
$max = $year.'-'.$month.'-'.$max_day.' 23:59:59';
$sql = "select t.enterdate,count(*) as total_num,sum(t.total_price) as amount (select date_format(enterdate,'%e') as enterdate,total_price from orders where enterdate between {$min} and {$max}) t group by t.enterdate order by t.enterdate";
$return = mysqli_query($sql);
로그인 후 복사

이 SQL은 간단하지만 매번 30개의 쿼리가 필요하므로 응답 시간이 심각하게 느려집니다.

Optimization

SQL을 사용하여 일일 총 수량을 직접 쿼리하는 방법은 무엇입니까?

이때, 먼저 mysql의 date_format 함수를 사용하여 서브쿼리에서 당월의 주문을 모두 알아내고, date_format 함수를 사용하여 Enterdate를 일수로 변환하고, 그런 다음 그룹화 기준 그룹 통계를 선택하세요. 코드는 다음과 같습니다.

rrreee이 기사의 사례를 읽으신 후 방법을 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 도서:


Mysqld_multi 배포 독립 실행형 자세한 설명

🎜🎜🎜하나의 SQL 문으로 여러 데이터베이스를 쿼리하는 방법🎜🎜🎜🎜🎜React를 사용하여 구성 요소 라이브러리를 개발하는 방법🎜🎜🎜🎜🎜🎜

위 내용은 PHP+MySQL 타이밍 데이터 통계 최적화의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿