fromdate, todate 구하는게 잘 이해가안되네요.
fromdate, todate 구하는게 잘 이해가안되네요..
알고리즘을 자세히 설명해주실 순 없으신가요?
답변 2
1
우선 아래의 쿼리를 수행하시어 좀 더 상세한 부분들의 결과값을 확인하십시오.
교안의 첫번째 쿼리를 세부적으로 분해한 내용입니다.
WITH RECURSIVE tmp AS (SELECT 1 AS id UNION ALL SELECT id+1 FROM tmp WHERE id<12)
SELECT
id,
CURRENT_DATE() current_day,
(id- 2)*7 days,
DAYOFWEEK(CURRENT_DATE())+ 6 fromdate_days,
DATE_SUB(CURRENT_DATE(),INTERVAL (id- 2)*7+DAYOFWEEK(CURRENT_DATE())+ 6 DAY) AS fromdate,
DAYOFWEEK(CURRENT_DATE())- 0 todate_days,
DATE_SUB(CURRENT_DATE(),INTERVAL (id- 2)*7+DAYOFWEEK(CURRENT_DATE())- 0 DAY) AS todate
FROM tmp
ORDER BY id;
위에서 보면, "보라1번 - (주황1번 + 파랑1번)" 의 결과가 fromdate 입니다.(해당 주의 일요일)
또한, "보라1번 - (주황1번 + 초록1번)" 의 결과가 todate 입니다.(해당 주의 토요일)
더불어서 DAYOFWEEK(일자)의 결과값은 위에 기재한 바와 같이 일(1), 월(2),...,토(7)와 같이 정해진 정수값들을 출력합니다. 그에 따라 계산되어 만들어진 쿼리이며 이는 다양한 방식으로 수정하여 사용할 수 있습니다.
알고리즘이라면, id값이 순차적으로 변함에 따라 함께 변화하는 "(id- 2)*7" 값 등이 7씩 감소하는 것을 이용했다고 할 수 있습니다.
예를 들어, 유사 내부함수 WEEKDAY() 등을 통해 아래와 같이 "현재일을 기준으로 과거 요일들을 5주 전까지로 출력하기" 도 가능합니다. 사용하는 이에 따라 다양한 결과가 나올 수 있습니다. (WEEKDAY()는 출력 정수값이 다름)
SELECT
ADDDATE(CURDATE(), - WEEKDAY(CURDATE()) - 7*(id-1)+0) AS '월요일',
ADDDATE(CURDATE(), - WEEKDAY(CURDATE()) - 7*(id-1)+1) AS '화요일',
ADDDATE(CURDATE(), - WEEKDAY(CURDATE()) - 7*(id-1)+2) AS '수요일',
ADDDATE(CURDATE(), - WEEKDAY(CURDATE()) - 7*(id-1)+3) AS '목요일',
ADDDATE(CURDATE(), - WEEKDAY(CURDATE()) - 7*(id-1)+4) AS '금요일',
ADDDATE(CURDATE(), - WEEKDAY(CURDATE()) - 7*(id-1)+5) AS '토요일',
ADDDATE(CURDATE(), - WEEKDAY(CURDATE()) - 7*(id-1)+6) AS '일요일'
FROM urlcodemap
ORDER BY id LIMIT 5;
물론, DAYOFWEEK()의 경우 역시 다양하게 변형시켜 사용될 수 있습니다.
문제 풀이 1번 질문
0
20
1
아주 작은 정오표 전달드립니다.
0
49
2
mysql워크벤치를 실행할때마다 오류가 뜹니다. 해결 방법좀 가르켜주세요.
0
42
1
함수기반 인덱스
0
29
2
날짜 인덱스관련 질문
0
26
1
복합인덱스 확인법
0
23
0
order_product 까마귀발
0
44
2
공통 코드 , 계층 구조 질문
1
37
1
77번 문제
0
27
1
76번 문제
1
34
2
64번 문제 관련
0
37
2
2,3차 정규화 질문
0
43
2
수강완료 후 문의 드립니다.
1
47
2
실전 모의고사 난이도
0
56
2
Part2 기출 문제 및 해설 자료 파일 없음 형태
0
53
2
21번 마지막 설명에 대해 질문이 있습니다.
0
49
2
노랭이67번
0
35
1
[DB설계] 탈퇴 유저의 구독 정보 유지 및 이메일 마스킹 관련 질문입니다.
0
53
1
자연키 vs 대리키 실무질문
0
28
1
38번 문제 보기 3,4번
1
45
3
14번 문제
1
45
2
결재했는데도 강좌가 안보입니다.
0
49
1
모바일 앱 쿠폰
0
45
1
urlcodemap.sql 파일 다운 받는곳이 없어요
1
231
1





