[SQL] SQL ์ค‘๊ธ‰

2021. 8. 22. 19:39ยท๐Ÿฅ Web/โ” Back-end | etc.
728x90

์ง€๋‚œ๋ฒˆ ๊ธ€์— ์ด์–ด์„œ Mode์˜ SQL ํŠœํ† ๋ฆฌ์–ผ์„ ์ฝ๊ณ  ์ •๋ฆฌํ•˜๊ณ  ์‹ค์Šตํ•ด๋ณด๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์˜ค๋Š˜์€ Count๋ฅผ ํฌํ•จํ•œ ๊ธฐ์ดˆ ์‚ฐ์ˆ ์—ฐ์‚ฐ ๋ฐฉ๋ฒ•, ์กฐ๊ฑด, ๊ทธ๋ฆฌ๊ณ  join์— ๋Œ€ํ•ด์„œ ๋‹ค๋ค„๋ณด๋ ค๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ์ž˜๋ชป ์ดํ•ดํ–ˆ๊ฑฐ๋‚˜ ์˜ค๋ฅ˜๊ฐ€ ์žˆ๋Š” ๋ถ€๋ถ„์€ ์•Œ๋ ค์ฃผ์‹œ๋ฉด ์ •๋ง ๊ฐ์‚ฌํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค!

Mode์—์„œ ๋กœ๊ทธ์ธ ํ›„ ์ƒˆ report๋ฅผ ๋งŒ๋“œ์…”์„œ ๋”ฐ๋ผํ•˜์‹ค ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๋งํฌ ์•„๋ž˜์— ๋‹ฌ์•„๋‘๊ฒ ์Šต๋‹ˆ๋‹ค.

https://app.mode.com/

Count

SELECT COUNT(*)
  FROM tutorial.aapl_historical_stock_price

ํŠน์ • ์—ด์˜ ํ–‰์˜ ์ˆ˜๋ฅผ ๊ณ„์‚ฐํ•ฉ๋‹ˆ๋‹ค. *์„ ์ž…๋ ฅํ•˜๋ฉด ์ „์ฒด ํ–‰์˜ ์ˆ˜๋ฅผ ์ถœ๋ ฅํ•ฉ๋‹ˆ๋‹ค. high๋ฅผ ์ž…๋ ฅํ•˜๋Š” ๊ฒฝ์šฐ์—๋Š” null์ด ์•„๋‹Œ ํ–‰์˜ ์ˆ˜๋ฅผ ๊ณ„์‚ฐํ•ฉ๋‹ˆ๋‹ค( *๋ณด๋‹ค ํ•ญ์ƒ ์ž‘์•„์š”! )

์—ด์„ ์…€ ์ˆ˜๋„, ์ˆซ์ž๊ฐ€ ์•„๋‹Œ ๋ฐ์ดํ„ฐ๋„ ๊ฐฏ์ˆ˜๋ฅผ ์„ธ๋Š” ๊ฒƒ์ด๊ธฐ ๋•Œ๋ฌธ์— ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค.

SELECT COUNT(low) AS low
  FROM tutorial.aapl_historical_stock_price

--

SELECT COUNT(date) AS count_of_date  -- non-numerical
  FROM tutorial.aapl_historical_stock_price

SUM, MIN/MAX

null์„ 0 ์ทจ๊ธ‰ํ•ฉ๋‹ˆ๋‹ค. ์—ด์˜ ํ•ฉ๊ณ„๋ฅผ ์ถœ๋ ฅํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

SELECT SUM(volume)
  FROM tutorial.aapl_historical_stock_price

ํ•ด๋‹น ์—ด์—์„œ์˜ ์ตœ์†Œ๊ฐ’๊ณผ ์ตœ๋Œ€๊ฐ’์„ ์ถœ๋ ฅํ•ฉ๋‹ˆ๋‹ค.

SELECT MIN(volume) AS min_volume,
       MAX(volume) AS max_volume
  FROM tutorial.aapl_historical_stock_price

AVG

SELECT AVG(high)
  FROM tutorial.aapl_historical_stock_price

์—ด์˜ ํ‰๊ท ์„ ๊ณ„์‚ฐํ•˜๋ฉฐ, ์ˆซ์ž์—๋งŒ ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค.

GROUP BY, HAVING

SELECT year,
       month,
       COUNT(*) AS count
  FROM tutorial.aapl_historical_stock_price
 GROUP BY year, month

์„ค์ •ํ•œ ๊ฐ’๋“ค์„ ๊ธฐ์ค€์œผ๋กœ ๊ทธ๋ฃน์œผ๋กœ ๋ฌถ์–ด์ค๋‹ˆ๋‹ค. ์˜ˆ์ œ์˜ ๊ฒฝ์šฐ์—๋Š” year๊ณผ month๊ฐ€ ๊ฐ™์€ ํ•ญ๋ชฉ๋“ค์„ ํ•œ ๊ทธ๋ฃน์œผ๋กœ ๋ฌถ๊ณ  count๋ฅผ ์ถœ๋ ฅํ•ด์ฃผ๋Š” ๊ฒƒ์ด ๋ฉ๋‹ˆ๋‹ค.

SELECT year,
       month,
       MAX(high) AS month_high
  FROM tutorial.aapl_historical_stock_price
 GROUP BY year, month
HAVING MAX(high) > 400
 ORDER BY year, month

HAVING์€ WHERE์˜ ๊ทธ๋ฃนํ™” ๋ฒ„์ „์ด๋ผ๊ณ  ์ƒ๊ฐํ•˜์‹œ๋ฉด ๋ฉ๋‹ˆ๋‹ค. ๊ทธ๋ฃนํ™”๋œ ํ•ญ๋ชฉ๋“ค์— ์กฐ๊ฑด ํ•„ํ„ฐ๋ง์„ ๊ฑธ์–ด์ค„ ์ˆ˜ ์žˆ์–ด์š”.

Query clause order

์ฟผ๋ฆฌ ์ˆœ์„œ๋Š” SELECT - FROM - WHERE - GROUP BY - HAVING - ORDER BY ๋กœ ์ด๋ฃจ์–ด์ ธ ์žˆ์Šต๋‹ˆ๋‹ค.

CASE

SELECT player_name,
       year,
       CASE WHEN year = 'SR' THEN 'yes'
            ELSE NULL END AS is_a_senior
  FROM benn.college_football_players

์ผ๋ฐ˜ ํ”„๋กœ๊ทธ๋ž˜๋ฐ์˜ switch - case๋ฌธ๊ณผ ๋™์ผํ•ฉ๋‹ˆ๋‹ค. WHEN = if์ด๋ฉฐ, ์กฐ๊ฑด๋ฌธ์„ ๋งŒ์กฑํ•˜๋ฉด 'yes'๋ฅผ, ๋งŒ์กฑํ•˜์ง€ ์•Š์œผ๋ฉด NULL์„ ์ƒˆ๋กœ ์ถ”๊ฐ€๋œ is_a_senior ์—ด์— ์ถ”๊ฐ€ํ•˜๋Š” ๋™์ž‘์„ ์ˆ˜ํ–‰ํ•ด์š”.

SELECT player_name,
       weight,
       CASE WHEN weight > 250 THEN 'over 250'
            WHEN weight > 200 THEN '201-250'
            WHEN weight > 175 THEN '176-200'
            ELSE '175 or under' END AS weight_group
  FROM benn.college_football_players

์—ฌ๋Ÿฌ ์กฐ๊ฑด์„ ์ถ”๊ฐ€ํ•˜๋Š” ๊ฒƒ๋„ ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค.

SELECT CASE WHEN year = 'FR' THEN 'FR'
            ELSE 'Not FR' END AS year_group,
            COUNT(1) AS count
  FROM benn.college_football_players
GROUP BY CASE WHEN year = 'FR' THEN 'FR'
              ELSE 'Not FR' END

COUNT์™€ ํ•จ๊ป˜ ์“ฐ๋Š” ๊ฒฝ์šฐ๊ฐ€ ๋งŽ์€๋ฐ, ์œ„ ์˜ˆ์ œ๋ฅผ ๋œฏ์–ด๋ณด๋ฉด,

SELECT CASE WHEN year = 'FR' THEN 'FR'
            ELSE 'Not FR' END AS year_group,
            *
  FROM benn.college_football_players

์—ฌ๊ธฐ๊นŒ์ง€ ์‹คํ–‰ํ–ˆ์„ ๋•Œ๋Š” ์•„๋ž˜์™€ ๊ฐ™์€ ๊ฒฐ๊ณผ๊ฐ€ ๋‚˜์˜ค๋Š” ๊ฒƒ์„ ํ™•์ธ ํ•  ์ˆ˜ ์žˆ์–ด์š”.

์ œ์ผ ์•ž ๋ผ์ธ์ด year_group์ด๋ฏ€๋กœ count๋„ ์ œ์ผ ์•ž ๋ผ์ธ์„ ๊ธฐ์ค€์œผ๋กœ ํ•˜๋„๋ก ๋˜์–ด์žˆ์Šต๋‹ˆ๋‹ค(COUNT(1) AS count)

๊ทธ๋ฆฌ๊ณ  count ๊ฒฐ๊ณผ๋ฅผ ๊ทธ๋ฃนํ™”ํ•ด์„œ ์ถœ๋ ฅํ•ด์•ผํ•˜๋ฏ€๋กœ GROUP BY ๋ฅผ CASE๋ฌธ์œผ๋กœ ๋‚˜๋ˆ ์„œ ์‹คํ–‰ํ•˜๋ฉด

์ด๋Ÿฐ ๊ฒฐ๊ณผ๋ฅผ ๋ณผ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ด ์˜ˆ์ œ๋Š” ์ƒˆ๋กœ countํ•œ ํ–‰์— ์ƒˆ ์ด๋ฆ„์„ ๋ถ™์—ฌ์ฃผ๊ธฐ ์œ„ํ•ด ์œ„์™€ ๊ฐ™์€ ์ž‘์—…์„ ๊ฑฐ์ณค๋Š”๋ฐ, ๊ฐ„๋‹จํ•˜๊ฒŒ๋Š” ์•„๋ž˜์™€ ๊ฐ™์ด ์“ธ ์ˆ˜๋„ ์žˆ์–ด์š”.

SELECT CASE WHEN year = 'FR' THEN 'FR'
            ELSE 'Not FR' END AS year_group,
            COUNT(1) AS count
  FROM benn.college_football_players
GROUP BY year_group

๋ฐ˜๋Œ€๋กœ COUNT ์•ˆ์— CASE๋ฅผ ๋„ฃ์„ ์ˆ˜๋„ ์žˆ์Šต๋‹ˆ๋‹ค.

SELECT COUNT(CASE WHEN year = 'FR' THEN 1 ELSE NULL END) AS fr_count,
       COUNT(CASE WHEN year = 'SO' THEN 1 ELSE NULL END) AS so_count,
       COUNT(CASE WHEN year = 'JR' THEN 1 ELSE NULL END) AS jr_count,
       COUNT(CASE WHEN year = 'SR' THEN 1 ELSE NULL END) AS sr_count
  FROM benn.college_football_players

DISTINCT

๊ณ ์œ ๊ฐ’์„ ์ถœ๋ ฅํ•ฉ๋‹ˆ๋‹ค.

SELECT COUNT(DISTINCT month) AS unique_months
  FROM tutorial.aapl_historical_stock_price

์œ„ ์˜ˆ์ œ์ฒ˜๋Ÿผ ์“ฐ๋ฉด, month์˜ ๊ณ ์œ ํ•œ ๊ฐ’์˜ ๊ฐœ์ˆ˜๋ฅผ ์„ธ์„œ unique_months์— ์ถ”๊ฐ€ํ•˜๋„๋ก ๋˜์–ด์žˆ๋‹ค. ๋‹ฌ์€ ์ด 12๊ฐœ ์žˆ์œผ๋ฏ€๋กœ 12๊ฐ€ ์ถ”๊ฐ€๋˜๋Š” ๊ฒƒ์„ ๋ณผ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

SELECT month,
       AVG(volume) AS avg_trade_volume
  FROM tutorial.aapl_historical_stock_price
 GROUP BY month
 ORDER BY 2 DESC

์œ„ ์ฝ”๋“œ์—์„œ๋Š” ๋‹ฌ๊ณผ ๊ฑฐ๋ž˜๋Ÿ‰์˜ ํ‰๊ท ์„ ๊ธฐ์ค€์œผ๋กœ, month๋กœ ๊ทธ๋ฃนํ™”ํ•˜๊ณ  ๊ฑฐ๋ž˜๋Ÿ‰ ํ‰๊ท ์œผ๋กœ ์ •๋ ฌํ–ˆ์–ด์š”. ๊ฑฐ๋ž˜๋Ÿ‰ ํ‰๊ท ์€ ๋‹ฌ์„ ๊ทธ๋ฃนํ™”ํ–ˆ์œผ๋ฏ€๋กœ ๊ฐ ์›”์— ํ•ด๋‹นํ•˜๋Š” ๋ชจ๋“  ๊ฑฐ๋ž˜๋Ÿ‰์˜ ํ‰๊ท ์ด๋ผ๊ณ  ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

SQL join - ๊ด€๊ณ„ํ˜• ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค

Visual JOIN

 

Visual JOIN

Visual JOIN Understand how joins work by interacting and see it visually INNER JOIN (or JOIN) OUTER JOIN (with UNION) Description » Hide description » {{ sql[current_join].desc }} Users ID Name {{user.id}} X {{user.name}} Add JOIN Name Like {{ join.name

joins.spathon.com

๋งŽ์€ ๋ฐ์ดํ„ฐ๊ฐ€ ์กด์žฌํ•  ๋•Œ ๋ฐ์ดํ„ฐ๋ฅผ ํ•˜๋‚˜ ๋ณ€๊ฒฝํ•˜๋Š”๋ฐ ์•„์ฃผ ๋งŽ์€ ๋น„์šฉ์ด ๋ฐœ์ƒํ•˜๋Š” ๊ฒƒ์€ ์–ด๋ ต์ง€ ์•Š๊ฒŒ ์˜ˆ์ƒํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ ๊ฒฐํ•ฉ(join)์„ ํ†ตํ•ด ํŠน์ • ๋ถ€๋ถ„์— ์ผ์น˜์‹œ์ผœ์„œ ์—ฐ๊ฒฐํ•ด์คŒ์œผ๋กœ์จ ๋น„์šฉ์„ ์ค„์ผ ์ˆ˜๊ฐ€ ์žˆ๋Š”๋ฐ, ์ด ์ˆ˜๋งŽ์€ join๋“ค์— ๋Œ€ํ•ด์„œ ๊ฐ„๋‹จํžˆ ์‚ดํŽด๋ด…์‹œ๋‹ค.

SELECT *
  FROM benn.college_football_players players
  JOIN benn.college_football_teams teams
    ON teams.school_name = players.school_name

players ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์˜ school_name์™€ teams ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์˜ school_name ๊ฐ€ ๊ฐ™์€ ๋ถ€๋ถ„์„ players์— teams๋ฅผ ์ด์‹ํ•˜๋Š” ๊ฒƒ์ด ์šฐ๋ฆฌ์˜ ์ฒซ๋ฒˆ์งธ ๋ชฉํ‘œ์ž…๋‹ˆ๋‹ค.

  • teams ์ฟผ๋ฆฌ

  • players ์ฟผ๋ฆฌ

  • ๊ฒฐ๊ณผ

school name์ด ๊ฐ™์€ ๊ณณ์— teams์˜ ์ •๋ณด๋ฅผ ๋’ค์— ๋ถ™์—ฌ์„œ join ํ•ด์คฌ์Šต๋‹ˆ๋‹ค.

https://s3-us-west-2.amazonaws.com/secure.notion-static.com/92949540-3480-4253-8597-5e22d27b98c4/Untitled.png

Inner Join

๊ต์ง‘ํ•ฉ์ž…๋‹ˆ๋‹ค. ๊ธฐ๋ณธ์ ์œผ๋กœ ์ผ๋ฐ˜์ ์ธ join์„ ์ผ์„ ๋•Œ inner join์„ ๋œปํ•˜๊ฒŒ ๋ฉ๋‹ˆ๋‹ค.

SELECT players.*,
       teams.*
  FROM benn.college_football_players players
  JOIN benn.college_football_teams teams
    ON teams.school_name = players.school_name

players์™€ teams์˜ ๋ชฉ๋ก ์ค‘ school name์ด ๊ฐ™์€ ๊ฒƒ์„ ์ถ”๋ ค players์— teams๋ฅผ joinํ•ด์ฃผ๊ณ , ๊ทธ๊ฒƒ์„ ์ „์ฒด scv chart์— ์ถœ๋ ฅํ•ด์ฃผ๋Š” ์ฝ”๋“œ์ž…๋‹ˆ๋‹ค.

SELECT players.player_name,
       players.school_name,
       teams.conference
  FROM benn.college_football_players players
  JOIN benn.college_football_teams teams
    ON teams.school_name = players.school_name
 WHERE teams.division = 'FBS (Division I-A Teams)'

์ด ๊ฒฝ์šฐ์—๋Š” ์œ„์™€ ๊ฐ™์€ ์กฐ๊ฑด์— teams์˜ division ์กฐ๊ฑด์ด FBS์ธ ๊ฒƒ๋งŒ ๋ฝ‘์•„๋ƒˆ์–ด์š”.

SELECT A.ID,
             A.ENAME
             A.KNAME
FROM A INNER JOIN B
ON A.ID = B.ID

์œ„์™€ ๊ฐ™์ด ์ž‘์„ฑํ•œ ๊ฒฝ์šฐ, A์™€ B์˜ ID๊ฐ€ ๊ฐ™์€ ๊ฒƒ๋งŒ ์ถ”๋ ค์„œ SELECT๋ฉ๋‹ˆ๋‹ค. ๋‚˜๋จธ์ง€ A๋Š” ๋‹น์—ฐํžˆ SELECT๋˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.

Outer Join

ํ•ฉ์ง‘ํ•ฉ์ž…๋‹ˆ๋‹ค. ์ „๋ถ€ ๋‹ค ๋ชจ์•„์„œ ๋ณด์—ฌ์ฃผ๋Š” ๋ฐฉ์‹์ž…๋‹ˆ๋‹ค.

Left Join

๊ณตํ†ต์ ์ธ ๋ถ€๋ถ„๊ณผ left ์— ์žˆ๋Š” table 1์˜ ๋ถ€๋ถ„์„ ํฌํ•จํ•ฉ๋‹ˆ๋‹ค. 

SELECT companies.permalink AS companies_permalink,
       companies.name AS companies_name,
       acquisitions.company_permalink AS acquisitions_permalink,
       acquisitions.acquired_at AS acquired_date
  FROM tutorial.crunchbase_companies companies
  JOIN tutorial.crunchbase_acquisitions acquisitions
    ON companies.permalink = acquisitions.company_permalink

์œ„์™€ ๊ฐ™์ด ์‹คํ–‰ํ•˜๋ฉด ์•„๋ž˜์™€ ๊ฐ™์ด 280 North๊ฐ€ ๋‘ ๋ฒˆ ๋‚˜ํƒ€๋‚ฉ๋‹ˆ๋‹ค. ์ด ๊ฒฝ์šฐ table 2์— table 1๊ณผ ๊ฐ™์€ ํ•ญ๋ชฉ์ด ์žˆ๊ณ  ๊ทธ๋Œ€๋กœ joinํ–ˆ๊ธฐ ๋•Œ๋ฌธ์ด์—์š”.

SELECT companies.permalink AS companies_permalink,
       companies.name AS companies_name,
       acquisitions.company_permalink AS acquisitions_permalink,
       acquisitions.acquired_at AS acquired_date
  FROM tutorial.crunchbase_companies companies
  LEFT JOIN tutorial.crunchbase_acquisitions acquisitions
    ON companies.permalink = acquisitions.company_permalink

์ด๋ ‡๊ฒŒ ์‹คํ–‰ํ•˜๋ฉด null ๊ฐ’์„ ํฌํ•จํ•ด์„œ ๋“ค์–ด๊ฐ‘๋‹ˆ๋‹ค.

Right Join

left join๊ณผ ๋ฐ˜๋Œ€๋กœ table 1๊ณผ 2์˜ ๊ณตํ†ต๋ถ€๋ถ„๊ณผ table 2 ์ „์ฒด๊ฐ€ ํฌํ•จ๋ฉ๋‹ˆ๋‹ค. 

 


์•„์ง SQL์— ๋Œ€ํ•ด์„œ๋Š” ๊ณต๋ถ€๊ฐ€ ๋ชจ์ž๋ผ์„œ ์•„๋ฌด๋ž˜๋„ ์ง์ ‘ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋ฅผ ๋งŒ๋“ค์–ด๋ณด๊ฑฐ๋‚˜ ์‹ค์ „์—์„œ ์‚ฌ์šฉํ•˜๋ฉด์„œ ๋” ๋Š˜๋ฉด ์ˆ˜์ •ํ•˜๊ณ  ์ถ”๊ฐ€ํ•˜๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. mode๋Š” ์ฒ˜์Œ ์•Œ๊ณ  ์จ๋ดค๋Š”๋ฐ ๋ฌธ๋ฒ• ์—ฐ์Šตํ•˜๊ธฐ๋Š” ๊ฝค ์ข‹์€ ๊ฒƒ ๊ฐ™์•„์š”! ๊ทธ๋Ÿผ ๋‹ค์Œ ํฌ์ŠคํŒ…์—์„œ ๋ต™๊ฒ ์Šต๋‹ˆ๋‹ค :)

728x90
์ €์ž‘์žํ‘œ์‹œ ๋น„์˜๋ฆฌ ๋ณ€๊ฒฝ๊ธˆ์ง€ (์ƒˆ์ฐฝ์—ด๋ฆผ)

'๐Ÿฅ Web > โ” Back-end | etc.' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[Elasticsearch] Index Template ๊ตฌ์„ฑํ•˜๊ธฐ with Kibana & Logstash (1) - Setting  (0) 2023.07.06
[Elasticsearch] Logstash๋ฅผ ํ†ตํ•ด PostgreSQL๊ณผ Elastic Stack ์—ฐ๋™ํ•˜๊ธฐ  (0) 2023.06.29
[Elasticsearch] Logstash ์‚ฌ์šฉํ•ด๋ณด๊ธฐ  (0) 2023.06.29
[Elasticsearch] Elasticsearch ๊ธฐ๋ณธ ๊ฐœ๋… ๋ฐ ์„ค์น˜, kibana ์—ฐ๋™ํ•˜๊ธฐ  (1) 2023.06.29
[SQL] SQL ๊ธฐ์ดˆ  (0) 2021.07.24
'๐Ÿฅ Web/โ” Back-end | etc.' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [Elasticsearch] Logstash๋ฅผ ํ†ตํ•ด PostgreSQL๊ณผ Elastic Stack ์—ฐ๋™ํ•˜๊ธฐ
  • [Elasticsearch] Logstash ์‚ฌ์šฉํ•ด๋ณด๊ธฐ
  • [Elasticsearch] Elasticsearch ๊ธฐ๋ณธ ๊ฐœ๋… ๋ฐ ์„ค์น˜, kibana ์—ฐ๋™ํ•˜๊ธฐ
  • [SQL] SQL ๊ธฐ์ดˆ
darly213
darly213
ํ˜ธ๋ฝํ˜ธ๋ฝํ•˜์ง€ ์•Š์€ ๊ฐœ๋ฐœ์ž๊ฐ€ ๋˜์–ด๋ณด์ž
  • darly213
    ERROR DENY
    darly213
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (97)
      • ๐Ÿฌ ML & Data (50)
        • ๐ŸŒŠ Computer Vision (2)
        • ๐Ÿ“ฎ Reinforcement Learning (12)
        • ๐Ÿ“˜ ๋…ผ๋ฌธ & ๋ชจ๋ธ ๋ฆฌ๋ทฐ (8)
        • ๐Ÿฆ„ ๋ผ์ดํŠธ ๋”ฅ๋Ÿฌ๋‹ (3)
        • โ” Q & etc. (5)
        • ๐ŸŽซ ๋ผ์ดํŠธ ๋จธ์‹ ๋Ÿฌ๋‹ (20)
      • ๐Ÿฅ Web (21)
        • โšก Back-end | FastAPI (2)
        • โ›… Back-end | Spring (5)
        • โ” Back-end | etc. (9)
        • ๐ŸŽจ Front-end (4)
      • ๐ŸŽผ Project (8)
        • ๐ŸงŠ Monitoring System (8)
      • ๐Ÿˆ Algorithm (0)
      • ๐Ÿ”ฎ CS (2)
      • ๐Ÿณ Docker & Kubernetes (3)
      • ๐ŸŒˆ DEEEEEBUG (2)
      • ๐ŸŒ  etc. (8)
      • ๐Ÿ˜ผ ์‚ฌ๋‹ด (1)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ํ™ˆ
    • ๋ฐฉ๋ช…๋ก
    • GitHub
    • Notion
    • LinkedIn
  • ๋งํฌ

    • Github
    • Notion
  • ๊ณต์ง€์‚ฌํ•ญ

    • Contact ME!
  • 250x250
  • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.3
darly213
[SQL] SQL ์ค‘๊ธ‰
์ƒ๋‹จ์œผ๋กœ

ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”