집 >데이터 베이스 >MySQL 튜토리얼 >달력 테이블에 월의 주 번호를 효율적으로 추가하는 방법은 무엇입니까?
캘린더 테이블에서 월의 주 수 검색
한 달 내의 주 수를 결정하는 것은 달력 관리의 중요한 측면입니다. 이 문서에서는 기존 달력 테이블에 이 속성을 추가하는 문제를 다룹니다.
특정 날짜의 주 수를 계산하려면 다음 단계를 수행할 수 있습니다.
이 경우에는 다음 스키마를 가진 달력 테이블이 있습니다.
CREATE TABLE [TCalendar] ( [TimeKey] [int] NOT NULL , [FullDateAlternateKey] [datetime] NOT NULL , [HolidayKey] [tinyint] NULL , [IsWeekDay] [tinyint] NULL , [DayNumberOfWeek] [tinyint] NULL , [EnglishDayNameOfWeek] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [SpanishDayNameOfWeek] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [FrenchDayNameOfWeek] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [DayNumberOfMonth] [tinyint] NULL , [DayNumberOfYear] [smallint] NULL , [WeekNumberOfYear] [tinyint] NULL , [EnglishMonthName] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [SpanishMonthName] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [FrenchMonthName] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [MonthNumberOfYear] [tinyint] NULL , [CalendarQuarter] [tinyint] NULL , [CalendarYear] [char] (4) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [CalendarSemester] [tinyint] NULL , [FiscalQuarter] [tinyint] NULL , [FiscalYear] [char] (4) COLLATE SQL_Latin1_General_CP1_CI_AS NULL , [FiscalSemester] [tinyint] NULL , [IsLastDayInMonth] [tinyint] NULL , CONSTRAINT [PK_TCalendar] PRIMARY KEY CLUSTERED ( [TimeKey] ) ON [PRIMARY] ) ON [PRIMARY]
이 테이블에 월의 주 수를 추가하려면 다음 업데이트를 실행할 수 있습니다. 명령문:
update TCalendar set = WeekNumberOfMonth = DATEDIFF(week, DATEADD(MONTH, DATEDIFF(MONTH, 0, FullDateAlternateKey), 0), FullDateAlternateKey) +1
이 쿼리는 DATEDIFF 함수를 활용하여 현재 날짜와 해당 월의 1일(DATEADD를 사용하여 구함) 간의 차이를 계산합니다. 그런 다음 결과 일 수를 7로 나누고 1을 증가시켜 주 수를 결정합니다.
위 내용은 달력 테이블에 월의 주 번호를 효율적으로 추가하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!