세조목

SQL 정리(STR_TO_DATE, SQL 실행 순서, 데이터 삭제)(23.12.29) 본문

데이터 분석 공부/SQL

SQL 정리(STR_TO_DATE, SQL 실행 순서, 데이터 삭제)(23.12.29)

세조목 2023. 12. 30. 00:53

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해야한다.