๋ณธ๋ฌธ ๋ฐ”๋กœ๊ฐ€๊ธฐ

728x90

sql

2/22 ์ˆ˜ 1. ์ฝ”๋“œ ๋ฆฌ๋ทฐ - ๋ฆฌ๋ทฐ์ด ์ฒซ ๋ฒˆ์งธ, ์•ฝ์ ์„ ๋…ธ์ถœํ•˜์ง€ ์•Š๋Š” ๊ฒƒ์ด ์ค‘์š”: ์ฝ”๋“œ ์ปจ๋ฒค์…˜์ด ์ž˜ ์ง€์ผœ์กŒ๋Š”์ง€ ๋…ผ๋ฆฌ์ ์ธ ์˜ค๋ฅ˜๋‚˜ ์˜คํƒ€๊ฐ€ ์—†๋Š”์ง€ ๋ฐ˜๋ณต์ ์ธ ์ž‘์—…์„ ํ•˜๋‹ค ๋ˆ„๋ฝํ•œ ๋ถ€๋ถ„์ด ์žˆ์ง„ ์•Š์€์ง€ ์ด์ „ PR์—์„œ ์ง€์ ๋œ ์‹ค์ˆ˜๋ฅผ ๋‹ค์‹œ ํ•œ๋ฒˆ ๋ฐ˜๋ณตํ•˜๊ณ  ์žˆ์ง„ ์•Š๋Š”์ง€ ์‚ฌ์šฉ์ด ๊ถŒ์žฅ๋˜์ง€ ์•Š๋Š”(deprecated) ๊ตฌ์‹ ๊ธฐ๋Šฅ์„ ์‚ฌ์šฉํ•˜๊ณ  ์žˆ๋Š”์ง€ ์ฝ”๋“œ์˜ ์‹œ๊ฐ„ ๋ณต์žก๋„๋ฅผ ๋‚ฎ์ถœ ์ˆ˜ ์žˆ๋Š”์ง€ ์„ฑ๋Šฅ์ƒ ์ตœ์ ํ™” ๊ฐ€๋Šฅํ•œ ๋ถ€๋ถ„์ด ๋” ๋‚จ์•„์žˆ์ง€๋Š” ์•Š์€์ง€ ๋‘ ๋ฒˆ์งธ, ๋ฆฌ๋ทฐ์–ด๊ฐ€ ๋ฏธ๋ฆฌ ๊ถ๊ธˆํ•ดํ•  ์ˆ˜ ์žˆ๋Š” ๋ถ€๋ถ„๊นŒ์ง€ ๊ณ ๋ คํ•ด ์„ค๋ช…์„ ๋‚จ๊น€: ๋ณ€์ˆ˜๋‚˜ ํ•จ์ˆ˜์— ์™œ ๊ทธ๋Ÿฌํ•œ ๋„ค์ด๋ฐ์„ ์‚ฌ์šฉํ–ˆ๋Š”์ง€ ์™ธ๋ถ€ ํ”„๋กœ์ ํŠธ๋ฅผ ์ฐธ๊ณ ํ•  ๋•Œ, ์–ด๋–ค ๊ฒƒ์„ ์šฐ์„ ์ ์œผ๋กœ ์ฐธ๊ณ ํ–ˆ๋Š”์ง€ ์ฐธ๊ณ ํ•œ ๋ ˆํผ๋Ÿฐ์Šค๊ฐ€ ๊ณต์‹ ๋ ฅ์ด ์žˆ๋Š”์ง€ ์„ ํƒํ•œ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๊ฐ€ ๋‹ค๋ฅธ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์™€ ๋น„๊ตํ–ˆ์„ ๋•Œ ์–ด๋–ค ์žฅ์ ์ด ์žˆ๋Š”์ง€ ๋‚ด๊ฐ€ ์ง€๊ธˆ ์ˆ˜์ •ํ•˜๊ณ  ์žˆ๋Š” ์ฝ”๋“œ์—.. ๋”๋ณด๊ธฐ
1/28 ๊ธˆ ์„ค ์—ฐํœด๋ฅผ ์•ž๋‘” ๊ธˆ์š”์ผ!! JOIN : ๋‘ ๊ฐœ ์ด์ƒ์˜ ํ…Œ์ด๋ธ”์„ ์„œ๋กœ ๋ฌถ์–ด์„œ ํ•˜๋‚˜์˜ ๊ฒฐ๊ณผ ์ง‘ํ•ฉ์œผ๋กœ ๋งŒ๋“ค์–ด ๋‚ด๋Š” ๊ฒƒ INNER JOIN : ๊ฐ€์žฅ ๋งŽ์ด ์‚ฌ์šฉ๋˜๋Š” ์กฐ์ธ. ์–‘์ชฝ ํ…Œ์ด๋ธ”์— ๋ชจ๋‘ ๋‚ด์šฉ์ด ์žˆ๋Š” ๊ฒƒ๋งŒ ์กฐ์ธ๋จ USE sqldb; SELECT * FROM UserTBL; SELECT * FROM buyTBL; SELECT * -- INNER JOIN FROM buyTBL INNER JOIN userTBL ON buyTBL.userID = userTBL.userID WHERE buyTBL.userID = 'JYP'; SELECT * FROM buyTBL INNER JOIN userTBL ON buyTBL.userID = userTBL.userID WHERE productName = '์šด๋™ํ™”'; SELECT B.. ๋”๋ณด๊ธฐ
1/27 ๋ชฉ ๋ชฉ์š”์ผ~~ WHERE ์กฐ๊ฑด์—์„œ ์‚ฌ์šฉํ•˜๋Š” AND·OR·BETWEEN·IN·LIKE ์—ฐ์‚ฐ์ž ํŒจํ„ด ๋งค์นญ : ์™€์ผ๋“œ์นด๋“œ๋ฅผ ์ด์šฉํ•ด์„œ ํŠน์ • ํŒจํ„ด๋งŒ ์กฐํšŒ. '%'๋Š” 0๊ฐœ ์ด์ƒ์˜ ๊ธ€์ž, '_'๋Š” 1๊ฐœ์˜ ๊ธ€์ž๋ฅผ ์˜๋ฏธํ•จ USE sqldb; -- sqldb schema ์ง€์ • SELECT * FROM userTBL; SELECT * FROM userTBL WHERE userName = '๊น€๊ฒฝํ˜ธ'; -- WHERE ์กฐ๊ฑด SELECT userID, userName FROM userTBL WHERE (birthYear >= 1970) AND (userHeight >= 182); SELECT userID, userName FROM userTBL WHERE (birthYear >= 1970) OR (userHeight >= 182);.. ๋”๋ณด๊ธฐ
1/26 ์ˆ˜ ์ˆ˜์š”์ผ~~ SQL์€ ๋Œ€์†Œ๋ฌธ์ž๋ฅผ ๊ตฌ๋ณ„ํ•˜์ง€ ์•Š์ง€๋งŒ, ๊ด€์šฉ์ ์œผ๋กœ keyword๋Š” ๋Œ€๋ฌธ์ž / ์‹๋ณ„์ž(์‚ฌ์šฉ์ž ์ •์˜ ๋ณ€์ˆ˜·ํ•จ์ˆ˜·ํ…Œ์ด๋ธ”·์ธ๋ฑ์Šค·๋ทฐ ์ด๋ฆ„)๋Š” ์†Œ๋ฌธ์ž๋ฅผ ์ด์šฉ View : ์‹ค์ œ ๋ฐ์ดํ„ฐ๋ฅผ ๊ฐ€์ง€๊ณ  ์žˆ์ง€ ์•Š์€ ๊ฐ€์ƒ์˜ ํ…Œ์ด๋ธ”, ์ง„์งœ ํ…Œ์ด๋ธ”์— ๋งํฌ๋œ ๊ฐœ๋…, ๋ทฐ๋ฅผ SELECT ํ•˜๋ฉด ํ…Œ์ด๋ธ”์˜ ํ…Œ์ดํ„ฐ๋ฅผ ์กฐํšŒํ•˜๋Š” ๊ฒƒ๊ณผ ๋™์ผํ•œ ๊ฒฐ๊ณผ CREATE VIEW shopdb.v_memberTBL -- View ์ƒ์„ฑ AS SELECT memberName, memberAddr FROM shopdb.membertbl; -- ๋งํฌํ•  ํ…Œ์ด๋ธ” ์ง€์ • SELECT * FROM shopdb.v_memberTBL; -- View ์ƒ์„ฑ ์‹œ ์ž…๋ ฅํ•œ SELECT๋ฌธ ์‹คํ–‰ DROP DATABASE shopdb; -- schema ๋ฐฑ์—… ํ›„ ์‚ญ์ œ ๋ฐฑ์—… ๋ณต์› ๋ฐ์ด.. ๋”๋ณด๊ธฐ
1/25 ํ™” โ™จ์š”์ผ~ ํŒŒ์ด์ฌ์„ ๋๋‚ด๊ณ , ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋กœ ๋„˜์–ด์™”์Šต๋‹ˆ๋‹ค~ Datebase : ๋ฐ์ดํ„ฐ์˜ ์ง‘ํ•ฉ. ๋Œ€์šฉ๋Ÿ‰์˜ ๋ฐ์ดํ„ฐ๋ฅผ ์ฒด๊ณ„์ ์œผ๋กœ ๊ตฌ์„ฑํ•ด ๋†“์€ ๊ฒƒ DBMS : database management system, DB๋ฅผ ํŒŒ์ผ๋กœ ๋งŒ๋“ค์–ด ์ €์žฅ·๊ด€๋ฆฌํ•ด์ฃผ๋Š” SW ex) DB2(IBM, ์ดˆ๋Œ€ํ˜•/๋ฉ”์ธํ”„๋ ˆ์ž„), Oracle DB(Oracle, ๋Œ€ํ˜•), MySQL(Oracle, ์ค‘·์†Œํ˜•) ๊ณ„์ธตํ˜• DBMS(hierachical DBMS) : ๋ฐ์ดํ„ฐ์˜ ์—ฐ๊ณ„๊ฐ€ ์‰ฝ์ง€ ์•Š์Œ Network DBMS : ๊ณ„์ธตํ˜• DBMS์˜ ๋ง๋‹จ๋ผ๋ฆฌ ์—ฐ๊ฒฐํ•ด์คŒ, ๋‹จ ๊ตฌํ˜„์ด ์–ด๋ ค์›€ ๊ด€๊ณ„ํ˜• DBMS(relational DBMS) : DB๋ฅผ ๋ถ„๋ฅ˜ํ•˜์—ฌ Table ๊ตฌ์กฐ๋ฅผ ์ •ํ•ด ๊ทธ ๋ฐ‘์— DB๋ฅผ ์Œ“์Œ, ์ •ํ˜•ํ™”๋œ ๋ฐ์ดํ„ฐ์— ํŠนํ™”๋จ ๊ฐ์ฒด์ง€ํ–ฅ DBMS(orbject oriented) .. ๋”๋ณด๊ธฐ

728x90