SQL 정리(STR_TO_DATE, SQL 실행 순서, 데이터 삭제)(23.12.29)
1. STR_TO_DATE
STR_TO_DATE 함수는 문자를 날짜로 변경해주는 함수이다.
예를 들어 위와 같은 테이블이 있다고 하자.
order_date 컬럼을 보면
문자열인것을 알 수 있다.
그런데 우리가 날짜 계산을 할 때는 문자열이 아닌 숫자여야하기때문에
문자열을 날짜로 바꿔줘야한다.
이 때 활용하는 함수가 바로 STR_TO_DATE함수이다.
문법은 STR_TO_DATE(컬럼명, 형식)인데
여기서 형식이란 %Y(y), %M(m), %D(d) 등을 얘기한다.
다시말해 연월일을 표시할 지, 연월만 표시할 지, 월만 표시할 지를 정해주는 것이다.
예를들어 위 order_date 컬럼을 연월만 표시하고싶다면
STR_TO_DATE(order_date, '%Y-%m')로 적으면 된다.
select min(order_date)
from list_of_orders
where str_to_date(order_date, '%Y-%m-%d')
만약 일자 中 가장 예전의 일자를 찾고자한다면 위와 같이 order_date를 날짜로 바꿔주고
min함수를 활용해주면 된다.
2. SQL 실행순서
SQL을 적는 순서는 다음과 같다.
SELECT
FROM
WHERE
GROUP BY
HAVING
ORDER BY
그런데 읽는 순서는 위 순서가 아니라 아래의 순서를 따른다.
From -> Where -> Group by -> Having -> Select -> Order by
3. 데이터 삭제(Delete)
테이블에서 데이터를 삭제할 때는 Delete함수를 활용할 수 있다.
Price | Taste | Type |
34555 | Sour | Indian |
30872 | Spicy | Korean |
27608 | null | null |
위와 같은 테이블이 있다고 가정했을때
Taste와 Type 컬럼의 속성값이 null이어서 해당 row를 지우고싶은 상황이라고 가정해보자
어떻게 해당 row를 지울 수 있을까??
이 때 Delete 함수를 사용하는 것이다.
DELETE FROM food_price
WHERE Price is 27608
SELECT절 없이 위 쿼리만 입력하면 된다.
단 한 번 제거한 row는 데이터를 다시 가져오지 않는한 복구가 불가능하기때문에
정말 제거할 row인지 아닌지 확실하게 판단해서 delete해야한다.