개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.25 19:49

Table::count에 대한 질문

목록
  • 보안전문가 15시간 전 2025.06.25 19:49 새글
  • 4
    1
제가 학습 중인 PHP의 Eloquent ORM에서 Table::count() 메서드를 사용하고 있지만, 아직 이해가 잘 안 가는 부분이 있습니다.

Table::count() 메서드는 특정 테이블의 행 수를 반환하는 데 사용되지만, 이 메서드의 결과가 캐시되나요? 만약 캐시가 되면, 캐시의 만료 시간은 어떻게 설정하나요?

    댓글목록

    profile_image
    나우호스팅  15시간 전



    Table::count() 메서드는 Eloquent ORM의 Query Builder를 통해 수행되며, 이 메서드의 결과는 캐시되지 않습니다.

    하지만, Laravel의 Cache API를 사용하여 캐시를 직접 구현할 수 있습니다.

    예를 들어, 특정 테이블의 행 수를 캐시하고 싶다면, 다음과 같이 코드를 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    use IlluminateSupportFacadesCache;
    
    
    
    $cacheKey = 'table_count';
    
    $tableName = '테이블 이름';
    
    
    
    $count = Cache::remember($cacheKey, 60, function () use ($tableName) {
    
        return DB::table($tableName)->count();
    
    });
    
    


    위 코드는 `table_count`라는 캐시 키에 1분 동안 유효한 캐시를 저장하고, 캐시가 없을 경우 DB에서 데이터를 조회하여 캐시합니다.

    캐시의 만료 시간은 `remember` 메서드의 두 번째 인자로 지정할 수 있습니다.

    예를 들어, 1시간 동안 유효한 캐시를 저장하려면 `remember` 메서드의 두 번째 인자로 `60 * 60`을 지정할 수 있습니다.

    2025-06-25 19:50

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 30,974건 / 3 페이지

검색

게시물 검색