강의

멘토링

커뮤니티

Cộng đồng Hỏi & Đáp của Inflearn

Hình ảnh hồ sơ của scryid8884
scryid8884

câu hỏi đã được viết

Sách truy vấn SQL để sử dụng khi cần, Phần I

Tạo bảng tạm thời và CHỌN bằng một câu lệnh SQL

fromdate, todate 구하는게 잘 이해가안되네요.

Đã giải quyết

Viết

·

493

0

fromdate, todate 구하는게 잘 이해가안되네요..

 

알고리즘을 자세히 설명해주실 순 없으신가요?

sqlmariadbheidisql

Câu trả lời 2

1

swa님의 프로필 이미지
swa
Người chia sẻ kiến thức

우선 아래의 쿼리를 수행하시어 좀 더 상세한 부분들의 결과값을 확인하십시오.

교안의 첫번째 쿼리를 세부적으로 분해한 내용입니다.

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;

image위에서 보면, "보라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()의 경우 역시 다양하게 변형시켜 사용될 수 있습니다.

scryid님의 프로필 이미지
scryid
Người đặt câu hỏi

감사합니다

1

swa님의 프로필 이미지
swa
Người chia sẻ kiến thức

안녕하세요 scryid 님.

문의하신 질문이 관련된 강좌의 제목이 "SQL 한 문장으로..." 가 맞을까요? 해당 내용이 보이지 않아서요.

특정 강좌와 해당 부분을 말씀해 주시면 좋겠습니다.

scryid님의 프로필 이미지
scryid
Người đặt câu hỏi

스케줄을 위한 기간 리스트 가져오기입니다

Hình ảnh hồ sơ của scryid8884
scryid8884

câu hỏi đã được viết

Đặt câu hỏi