์ผ | ์ | ํ | ์ | ๋ชฉ | ๊ธ | ํ |
---|---|---|---|---|---|---|
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 |
- ์๋ฐ์คํฌ๋ฆฝํธ ๊ณต๋ถ
- Android
- JavaScript
- ์๋ฐํ๋ก๊ทธ๋๋ฐ
- ์คํธ๋ฆผ๋ฆฟ ๊ธฐ๋ณธ
- db
- ์คํธ๋ฆผ๋ฆฟ
- Matplotlib ๊ธฐ์ด
- Streamlit๊ธฐ์ด
- ์๋ฐ์คํฌ๋ฆฝํธ
- streamlit
- ๋ฐ์ดํฐ๋ฒ ์ด์ค
- MySQL
- ํ๋ค์ค๊ณต๋ถ
- RESTful API
- ์๋๋ก์ด๋ ์ฑ ๊ฐ๋ฐ
- ํ์ด์ฌ
- ์๋๋ก์ด๋ ์คํ๋์ค
- ์น๋์๋ณด๋ ๊ธฐ์ด
- Streamlit๊ธฐ๋ณธ
- ์๋ฐ์ด๋ณด
- serverless
- ์๋ฐ
- ํ์ด์ฌ๊ณต๋ถ
- java
- ์๋ฐ๊ณต๋ถ
- Pandas
- ์น๋์๋ณด๋ ์ ์
- ์๋ฐ๊ธฐ์ด
- ํ๋ค์ค
- Today
- Total
ruriruriya
[DB] ๋ฐ์ดํฐ๋ฒ ์ด์ค MySQL - case,if ์กฐ๊ฑด๋ฌธ ์์ฑํ๋ ๋ฐฉ๋ฒ ๋ณธ๋ฌธ
[DB] ๋ฐ์ดํฐ๋ฒ ์ด์ค MySQL - case,if ์กฐ๊ฑด๋ฌธ ์์ฑํ๋ ๋ฐฉ๋ฒ
๋ฃจ๋ฆฌ์ผใ 2023. 12. 1. 14:17
MySQL์์ CASE ๋ฌธ๊ณผ IF ๋ฌธ์ ์กฐ๊ฑด๋ถ ๋ก์ง์ ์ํํ๋๋ฐ ์ฌ์ฉ๋๋ค. ์ด๋ฅผ ํตํด ์กฐ๊ฑด์ ๋ฐ๋ผ ๋ค๋ฅธ ๊ฐ์ ๋ฐํํ๊ฑฐ๋ ํน์ ์กฐ๊ฑด์ ๋ฐ๋ผ ๋ค๋ฅธ ์์ ์ ์ํํ ์ ์๋ค.
์ฌ์ฉํ ํ ์ด๋ธ(books)
1. CASE๋ฌธ ์ฌ์ฉ๋ฐฉ๋ฒ
SQL์ case ๋ฌธ์ ๋ค๋ฅธ ์ธ์ด๋ ๋น์ทํ๊ฒ ์ฐ์ธ๋ค.
์๋๋ case์ ๊ธฐ๋ณธ ๊ตฌ์กฐ์ด๋ค.
์์ ๋ก ์ด๋ป๊ฒ ์๋๋๋์ง ์์๋ณด์.
CASE ์ปฌ๋ผ๋ช
WHEN ๊ฐ1 THEN ๊ฒฐ๊ณผ
WHEN ๊ฐ2 THEN ๊ฒฐ๊ณผ
...
ELSE ๋๋จธ์ง ๊ฒฐ๊ณผ๊ฐ
END
์์ 01 -
์ถํ๋
๋๊ฐ 2000๋
์ด์์ธ ์ฑ
๋ค์, '์ต๊ทผ์ฑ
' ์ด๋ผ๊ณ ํ๊ณ ,
๊ทธ๋ ์ง ์์ ์ฑ
๋ค์ '์์ ์ฑ
'์ด๋ผ๊ณ ํ์ฌ,
type ์ด๋ผ๋ ์ปฌ๋ผ์ ์ถ๊ฐํ์ฌ ๊ฐ์ ธ์ค์์ค.
select * ,
case
when released_year >= 2000 then '์ต๊ทผ์ฑ
'
else '์์ ์ฑ
'
end as type
from books;
์์ 02 -
์ฌ๊ณ ๊ฐ 0๋ถํฐ 50๊น์ง์ด๋ฉด '*'
์ฌ๊ณ ๊ฐ 51๋ถํฐ 100๊น์ง์ด๋ฉด '**'
๊ทธ๋ ์ง ์์ผ๋ฉด '***' ์ผ๋ก ํ์ฌ, stock ์ด๋ผ๋ ์ปฌ๋ผ์ ์ถ๊ฐํ์์ค.
select * ,
case
when stock_quantity between 0 and 50 then '*'
when stock_quantity between 51 and 100 then '**'
else '***'
end as stock
from books;
2. IF ๋ฌธ ์ฌ์ฉ๋ฐฉ๋ฒ
์กฐ๊ฑด์ด 3๊ฐ ์ด์์ผ ๋๋ case ๊ตฌ๋ฌธ์ด ๋ ์ฌ์ฉํ๊ธฐ ํธํ์ง๋ง
์กฐ๊ฑด์ด 2๊ฐ๋ผ๋ฉด if ๊ตฌ๋ฌธ ํ์ค๋ก ๋ ์ฌํํ ์ฝ๋๋ฅผ ๋ง๋ค ์ ์๋ค.
์ case ๊ตฌ๋ฌธ์ ์์ 1๋ฒ์ ํ์ด๋ณด๋ฉด์ ๋น๊ตํด๋ณด์.
์์ 01 -
์ถํ๋
๋๊ฐ 2000๋
์ด์์ธ ์ฑ
๋ค์, '์ต๊ทผ์ฑ
' ์ด๋ผ๊ณ ํ๊ณ ,
๊ทธ๋ ์ง ์์ ์ฑ
๋ค์ '์์ ์ฑ
'์ด๋ผ๊ณ ํ์ฌ,
type ์ด๋ผ๋ ์ปฌ๋ผ์ ์ถ๊ฐํ์ฌ ๊ฐ์ ธ์ค์์ค.
select * , if(released_year >= 2000, '์ต๊ทผ์ฑ
', '์์ ์ฑ
') as type
from books;
CASE ๋ฌธ๊ณผ IF ๋ฌธ์ ๋ฐ์ดํฐ๋ฅผ ๋ณํํ๊ฑฐ๋ ์ฌ๋ฌ ์กฐ๊ฑด์ ๋ฐ๋ผ ๋ค๋ฅธ ๊ฒฐ๊ณผ๋ฅผ ๋ฐํํ ๋ ์ ์ฉํ๋ค. ๊ฐ๋จํ ๋ก์ง๋ถํฐ ๋ณต์กํ ์กฐ๊ฑด๊น์ง ๋ค์ํ ์ํฉ์์ ํ์ฉ๋ ์ ์๋ค.