집 >데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 이전 달의 마지막 날을 효율적으로 찾는 방법은 무엇입니까?
PostgreSQL에서 이전 달의 마지막 날 확인
이전 달의 마지막 날을 확인하는 것은 데이터베이스 쿼리의 일반적인 요구 사항입니다. PostgreSQL에는 지정된 날짜 범위 내의 레코드를 검색하는 효율적인 방법이 있습니다.
한 가지 간단한 접근 방식은 date_trunc() 함수를 사용하는 것입니다. 날짜 열의 경우 다음을 사용합니다.
SELECT * FROM tbl WHERE my_date BETWEEN date_trunc('month', now())::date - 1 AND now()::date
date_trunc('month', now()) 표현식에서 1을 빼고 이를 날짜로 변환하면 효과적으로 이전 달의 첫 번째 날( 예: 2011년 12월 1일). now()::date에 1을 추가하면 범위의 오늘 날짜가 모두 포함됩니다.
타임스탬프 열의 경우 약간 다른 접근 방식이 필요합니다.
SELECT * FROM tbl WHERE my_timestamp >= date_trunc('month', now()) - interval '1 day' AND my_timestamp < date_trunc('day', now()) + interval '1 day'
이 경우 간격은 '1일'은 이전 달의 마지막 날(예: 2011년 12월 31일)이 범위에 완전히 포함되는지 확인하는 데 사용됩니다. 상한에 '1일' 간격 표현을 사용하면 "오늘"도 포함됩니다.
이러한 방법을 사용하면 이전 달의 마지막 날을 정확하게 확인하고 원하는 날짜 범위에 속하는 레코드를 검색할 수 있습니다. PostgreSQL에서.
위 내용은 PostgreSQL에서 이전 달의 마지막 날을 효율적으로 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!