목차
단순화된 API 호출 데이터 구조
API 호출 추세 쿼리: Next.js API 엔드포인트
샘플 응답
주요 기능
결론
웹 프론트엔드 JS 튜토리얼 Prisma 및 Next.js를 사용하여 API 호출 추세 분석: 주, 월 또는 연도별 그룹화

Prisma 및 Next.js를 사용하여 API 호출 추세 분석: 주, 월 또는 연도별 그룹화

Jan 20, 2025 am 02:33 AM

Analyzing API Call Trends with Prisma and Next.js: Grouping by Week, Month, or Year

이 블로그 게시물은 Prisma를 사용하여 일, 월, 연도별로 데이터를 그룹화하는 실용적인 솔루션을 제공합니다. 나는 이 문제로 어려움을 겪었으므로 이 간소화된 접근 방식을 공유하고 있습니다. Next.js API 엔드포인트를 사용하여 Prisma 및 MongoDB를 사용한 API 호출 추세를 분석하고 시간 경과에 따른 성공률 및 호출 빈도에 중점을 둘 것입니다.

단순화된 API 호출 데이터 구조

효과적인 대시보드를 만들려면 API 호출을 시간 간격별로 그룹화해야 합니다. 간결한 Prisma 스키마를 사용해 보겠습니다.

<code>model ApiCall {
  id        String    @id @default(auto()) @map("_id") @db.ObjectId
  timestamp DateTime  @default(now())
  status    ApiCallStatus // Enum for success or failure.
}

enum ApiCallStatus {
  SUCCESS
  FAILURE
}</code>
로그인 후 복사

이 스키마는 추세 분석에 충분한 각 API 호출의 타임스탬프와 상태를 추적합니다.

API 호출 추세 쿼리: Next.js API 엔드포인트

이 Next.js API 엔드포인트는 API 호출 데이터를 집계하여 지정된 기간(연도, 월 또는 일)별로 그룹화합니다.

<code>import { NextRequest, NextResponse } from 'next/server';
import { startOfYear, endOfYear, startOfMonth, endOfMonth } from 'date-fns';

export async function GET(req: NextRequest) {
    const range = req.nextUrl.searchParams.get("range"); // 'year' or 'month'
    const groupBy = req.nextUrl.searchParams.get("groupby"); // 'yearly', 'monthly', 'daily'

    // Input validation
    if (!range || (range !== 'year' && range !== 'month')) {
        return NextResponse.json({ error: "Range must be 'year' or 'month'" }, { status: 400 });
    }

    if (!groupBy || (groupBy !== 'yearly' && groupBy !== 'monthly' && groupBy !== 'daily')) {
        return NextResponse.json({ error: "Group by must be 'yearly', 'monthly', or 'daily'" }, { status: 400 });
    }

    try {
        let start: Date, end: Date;
        if (range === 'year') {
            start = startOfYear(new Date());
            end = endOfYear(new Date());
        } else { // range === 'month'
            start = startOfMonth(new Date());
            end = endOfMonth(new Date());
        }

        let groupByFormat: string;
        switch (groupBy) {
            case 'yearly':
                groupByFormat = "%Y";
                break;
            case 'monthly':
                groupByFormat = "%Y-%m";
                break;
            case 'daily':
                groupByFormat = "%Y-%m-%d";
                break;
        }

        const apiCallTrends = await db.apiCall.aggregateRaw({
            pipeline: [
                {
                    $match: {
                        timestamp: { $gte: { $date: start }, $lte: { $date: end } }
                    }
                },
                {
                    $group: {
                        _id: { $dateToString: { format: groupByFormat, date: '$timestamp' } },
                        SUCCESS: { $sum: { $cond: [{ $eq: ['$status', 'SUCCESS'] }, 1, 0] } },
                        FAILURE: { $sum: { $cond: [{ $eq: ['$status', 'FAILURE'] }, 1, 0] } },
                        TOTAL: { $sum: 1 }
                    }
                },
                {
                    $sort: {
                        _id: 1
                    }
                }
            ]
        });

        return NextResponse.json({ apiCallTrends });
    } catch (error) {
        console.error(error);
        return NextResponse.json({ error: "An error occurred while fetching data." }, { status: 500 });
    }
}</code>
로그인 후 복사

샘플 응답

다음과 같은 요청:

<code>GET /api/your-endpoint?range=year&groupby=monthly</code>
로그인 후 복사

다음과 같은 반응이 나올 수 있습니다:

<code>{
  "apiCallTrends": [
    {
      "_id": "2025-01", // January 2025
      "SUCCESS": 120,
      "FAILURE": 15,
      "TOTAL": 135
    },
    {
      "_id": "2025-02", // February 2025
      "SUCCESS": 110,
      "FAILURE": 10,
      "TOTAL": 120
    },
    {
      "_id": "2025-03", // March 2025
      "SUCCESS": 130,
      "FAILURE": 20,
      "TOTAL": 150
    }
    // ... more monthly data
  ]
}</code>
로그인 후 복사

주요 기능

  • 유연한 시간 그룹화: 연도, 월, 일별로 쉽게 그룹화할 수 있습니다.
  • 종합적인 추세 분석: 기간별 성공/실패 횟수 및 합계를 제공합니다.
  • 강력한 오류 처리: 명확한 오류 응답을 포함합니다.
  • 최적화된 성능: 효율성을 위해 MongoDB의 집계 파이프라인을 활용합니다.

결론

이 접근 방식은 Prisma ORM을 사용하여 MongoDB 내에서 다양한 시간 범위로 그룹화된 타임스탬프 데이터를 쿼리하고 분석하는 강력하고 효율적인 방법을 제공합니다. 읽어주셔서 감사합니다! 더 많은 콘텐츠를 보려면 좋아요와 구독을 눌러주세요! GitHub와 LinkedIn에서 저와 소통하세요.

위 내용은 Prisma 및 Next.js를 사용하여 API 호출 추세 분석: 주, 월 또는 연도별 그룹화의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

JavaScript로 문자열 문자를 교체하십시오 JavaScript로 문자열 문자를 교체하십시오 Mar 11, 2025 am 12:07 AM

JavaScript로 문자열 문자를 교체하십시오

jQuery 날짜가 유효한지 확인하십시오 jQuery 날짜가 유효한지 확인하십시오 Mar 01, 2025 am 08:51 AM

jQuery 날짜가 유효한지 확인하십시오

jQuery는 요소 패딩/마진을 얻습니다 jQuery는 요소 패딩/마진을 얻습니다 Mar 01, 2025 am 08:53 AM

jQuery는 요소 패딩/마진을 얻습니다

10 JQuery Accordions 탭 10 JQuery Accordions 탭 Mar 01, 2025 am 01:34 AM

10 JQuery Accordions 탭

10 JQuery 플러그인을 확인할 가치가 있습니다 10 JQuery 플러그인을 확인할 가치가 있습니다 Mar 01, 2025 am 01:29 AM

10 JQuery 플러그인을 확인할 가치가 있습니다

노드 및 HTTP 콘솔로 HTTP 디버깅 노드 및 HTTP 콘솔로 HTTP 디버깅 Mar 01, 2025 am 01:37 AM

노드 및 HTTP 콘솔로 HTTP 디버깅

사용자 정의 Google 검색 API 설정 자습서 사용자 정의 Google 검색 API 설정 자습서 Mar 04, 2025 am 01:06 AM

사용자 정의 Google 검색 API 설정 자습서

jQuery div에 스크롤 바를 추가합니다 jQuery div에 스크롤 바를 추가합니다 Mar 01, 2025 am 01:30 AM

jQuery div에 스크롤 바를 추가합니다

See all articles