일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 태블로
- If
- lambda
- 시각화
- da
- 히트맵
- 기초통계
- streamlit
- 데이터 분석
- cross join
- Chat GPT
- 군집화
- 팀프로젝트
- jd
- 머신러닝
- SQLD
- SQL
- 크롤링
- Python
- 프로젝트
- pandas
- 프롬프트 엔지니어링
- 데이터분석
- GA4
- 클러스터링
- 서브쿼리
- data analyst
- 기초프로젝트
- 최종 프로젝트
- 전처리
- Today
- Total
세조목
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해야한다.
'데이터 분석 공부 > SQL' 카테고리의 다른 글
SQL 정리(개인과제 복습)(24.01.03) (1) | 2024.01.03 |
---|---|
SQL 정리(With절, 컬럼 전체의 합, View, Explain)(24.01.02) (0) | 2024.01.02 |
SQL 정리(Join - cross, left)(leetcode - 1280. Students and Examinations)(23.12.28) (1) | 2023.12.27 |
SQL 정리(Cross Join)(23.12.26) (0) | 2023.12.26 |
SQL 정리(self join)(23.12.22) (1) | 2023.12.22 |