๐Ÿ’ป ๊ฐœ๋ฐœ

ํ•™์Šต ๋‚ด์šฉ PL/SQL ์ด๋ž€ -> PROCEDURAL EXTENTION TO STRUCTURED QUERY LANGUAGE - ์˜ค๋ผํด ์ž์ฒด์— ๋‚ด์žฅ๋˜์–ด ์žˆ๋Š” ์–ธ์–ด์ด๋‹ค. SQL์„ ํ™•์žฅํ•œ ์ˆœ์ฐจ์ ์ธ ์–ธ์–ด - PROCEDURE, FUNCTION, TRIGGER(์ž๋™ํ˜ธ์ถœํ•จ์ˆ˜, CALL BACK) PL/SQL ๋ฌธ์€ BLOCK ๊ตฌ์กฐ๋กœ ๋‹ค์ˆ˜์˜ SQL ๋ฌธ์„ ํ•œ๋ฒˆ์— ORACLE DB๋กœ ๋ณด๋‚ด์„œ ์ฒ˜๋ฆฌํ•˜๋ฏ€๋กœ ์ˆ˜ํ–‰์†๋„๋ฅผ ํ–ฅ์ƒ ์‹œํ‚ฌ์ˆ˜ ์žˆ๋‹ค. - SCRIPT ๊ตฌ์กฐ DECLARE -- ์„ ์–ธ๋ถ€ MESSAGE VARCHAR2(10); BEGIN -- ์‹คํ–‰๋ถ€ MESSAGE := 'HELLO PL'; dbms_output.put_line('MESSAGE = ' || message); END; / 1. ์„ ์–ธ๋ถ€ : ๋ณ€์ˆ˜, ์ƒ์ˆ˜, ์ดˆ๊ธฐํ™” 2. ์‹คํ–‰..
ํ•™์Šต ๋‚ด์šฉ - SUB QUERY : QUERY ์•ˆ์˜ QUERY ํ•œ๊ฐœ์˜ ํ–‰(ROW, RECORD)์—์„œ ๊ฒฐ๊ณผ ๊ฐ’์ด ๋ฐ˜ํ™˜๋˜๋Š” QUERY SELECT ๋‹จ์ผ ROW ๋‹จ์ผ COLUMN ์ด์–ด์•ผ ํ•œ๋‹ค (์‚ฐ์ถœ๋˜๋Š” ๋ฐ์ดํ„ฐ๋Š” ํ•œ๊ฐœ, ์ปฌ๋Ÿผ๋„ ํ•œ๊ฐœ) FROM ๋‹ค์ค‘ ROW ๋‹ค์ค‘ COLUMN ๊ฐ€๋Šฅ WHERE ๋‹ค์ค‘ ROW ๋‹ค์ค‘ COLUMN ๊ฐ€๋Šฅ -- SELECT SELECT employee_id, first_name, (SELECT first_name FROM employees WHERE employee_id = 100) FROM employees; -- FROM SELECT employee_id, first_name FROM (SELECT employee_id, first_name FROM employees WHERE depart..
๋ฐฐ์—ด์„ ์ด์šฉํ•œ ๊ธฐ์ดˆ์ ์ธ ๋ฌธ์ œ์˜€๋‹ค. ๋‹ค๋งŒ ๋‹คํ’€๊ณ ๋‚˜์„œ ๋‹ค๋ฅธ ์‚ฌ๋žŒ๋“ค์˜ ๋ฌธ์ œ ํ’€์ด๋ฅผ ๋ณด๋‹ˆ, for๋ฌธ์—์„œ ์›ํ•˜๋Š” ๊ฐ’์„ ์ฐพ์•˜์„ ๋•Œ break๋ฌธ์„ ์‚ฌ์šฉํ•˜๋ฉด ๋” ๋Œ์ง€์•Š๊ณ  ๋‚˜์˜ฌ ์ˆ˜ ์žˆ๋‹ค๋Š” ์žฅ์ ์ด ์žˆ์—ˆ๋‹ค. ์‰ฌ์šด ๋ฌธ์ œ์—์„œ๋„ ๋ฉ”๋ชจ๋ฆฌ๋ฅผ ์กฐ๊ธˆ์ด๋ผ๋„ ๋” ์•„๋‚„ ์ˆ˜ ์žˆ๋Š” ๋ฐฉ๋ฒ•์„ ๊ณ ์‹ฌํ•˜์—ฌ ์ฐพ์•„๋ด์•ผ๊ฒ ๋‹ค. /* ๋ฌธ์ œ ์„ค๋ช… Stringํ˜• ๋ฐฐ์—ด seoul์˜ element์ค‘ Kim์˜ ์œ„์น˜ x๋ฅผ ์ฐพ์•„, ๊น€์„œ๋ฐฉ์€ x์— ์žˆ๋‹ค๋Š” String์„ ๋ฐ˜ํ™˜ํ•˜๋Š” ํ•จ์ˆ˜, solution์„ ์™„์„ฑํ•˜์„ธ์š”. seoul์— Kim์€ ์˜ค์ง ํ•œ ๋ฒˆ๋งŒ ๋‚˜ํƒ€๋‚˜๋ฉฐ ์ž˜๋ชป๋œ ๊ฐ’์ด ์ž…๋ ฅ๋˜๋Š” ๊ฒฝ์šฐ๋Š” ์—†์Šต๋‹ˆ๋‹ค. ์ œํ•œ ์‚ฌํ•ญ seoul์€ ๊ธธ์ด 1 ์ด์ƒ, 1000 ์ดํ•˜์ธ ๋ฐฐ์—ด์ž…๋‹ˆ๋‹ค. seoul์˜ ์›์†Œ๋Š” ๊ธธ์ด 1 ์ด์ƒ, 20 ์ดํ•˜์ธ ๋ฌธ์ž์—ด์ž…๋‹ˆ๋‹ค. Kim์€ ๋ฐ˜๋“œ์‹œ seoul ์•ˆ์— ํฌํ•จ๋˜์–ด ์žˆ์Šต๋‹ˆ๋‹ค. ..
ํ•™์Šต ๋‚ด์šฉ - Select ํ˜•์‹ : SELECT ( ๊ฐ’, ์ปฌ๋Ÿผ๋ช…, ํ•จ์ˆ˜, SUB QUERY) FROM (ํ…Œ์ด๋ธ”๋ช…, SUB QUERY) SELECT 1 FROM DUAL; SELECT * FROM EMP; - ํ˜„์žฌ ๊ณ„์ •์˜ ํ…Œ์ด๋ธ” ์ •๋ณด ๋ชจ๋‘ ๋ช…์„ธ SELECT * FROM TAB; - ALIAS (์ปฌ๋Ÿผ๋ช… ์„ค์ •) SELECT EMPNO AS "์‚ฌ์› ๋ฒˆํ˜ธ", SAL AS ์›”๊ธ‰, SAL * 12 "์ผ๋…„์น˜ ์—ฐ๋ด‰" FROM EMP; - DISTINCT : ์ค‘๋ณตํ–‰ ์‚ญ์ œ SELECT DISTINCT JOB FROM EMP; -- ์ค‘๋ณต ์ œ๊ฑฐ - WHERE ์กฐ๊ฑด์ ˆ -> if &&(AND), ||(OR), ( ) -- && == AND SELECT FIRST_NAME, LAST_NAME FROM EMPLOYEES WHERE F..
ํ•™์Šต ๋‚ด์šฉ - ํ…Œ์ด๋ธ” ์ƒ์„ฑ CREATE TABLE ํ…Œ์ด๋ธ”๋ช…( ์ปฌ๋Ÿผ๋ช…1 ์ž๋ฃŒํ˜•, ์ปฌ๋Ÿผ๋ช…2 ์ž๋ฃŒํ˜•, : : ); - ํ…Œ์ด๋ธ” ์‚ญ์ œ DROP TABLE ํ…Œ์ด๋ธ”๋ช…; - ์ž๋ฃŒํ˜• (Java vs DB) Java DB String VARCHAR2, CHAR, LONG int INTEGER, NUMBER double NUMBER Date DATE - ๋ฌธ์ž์—ด CHAR CREATE TABLE TB_CHAR( COL1 CHAR(10 BYTE), COL2 CHAR(10 CHAR), -- 11111 11113 -> 12BYTE(ํ•œ๊ธ€ 1๊ฐœ์“ฐ๋ฉด) COL3 CHAR(10) ); INSERT INTO ํ…Œ์ด๋ธ”๋ช…(์ปฌ๋Ÿผ๋ช…, ์ปฌ๋Ÿผ๋ช… ... ) VALUES( ๊ฐ’, ๊ฐ’ ... ) INSERT INTO TB_CHAR (COL1, COL2, COL3..
์ž๋ฐ”๋ฅผ ํ•œ๋‹ฌ ์กฐ๊ธˆ ์•ˆ๋˜๋Š” ๊ธฐ๊ฐ„๋™์•ˆ ๋ฐฐ์šฐ๊ณ , ์ด์ œ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋กœ ๋„˜์–ด๊ฐ”๋‹ค. ์ฒซ๋ฒˆ์งธ๋กœ ๋ฐฐ์šฐ๋Š”๊ฑด SQL. ๊ทธ์ค‘์—์„œ ์˜ค๋ผํด์„ ๋ฐฐ์šฐ๊ฒŒ ๋˜์—ˆ๋‹ค. ํ•™์›์—์„œ ๋ฐฐ์šด ๊ฐ„๋‹จํ•œ ์„ธํŒ…๋ฒ•๋„ ๊ฐ™์ด ์ ์–ด๋‘”๋‹ค. 1. ์˜ค๋ผํด ๊ณต์‹ ํ™ˆํŽ˜์ด์ง€๋กœ ๊ฐ€์„œ Oracle Database XE 11.2 ๋ฒ„์ „์„ ๋ฐ›๋Š”๋‹ค. (๋งํฌ : www.oracle.com/database/technologies/xe-prior-releases.html) 2. SQL Developer (Windows 64-bit with JDK 8 included)๋ฅผ ๋ฐ›๋Š”๋‹ค. (๋งํฌ : www.oracle.com/tools/downloads/sqldev-downloads.html) 3. OracleXE112_Win64 ์••์ถ•์„ ํ’€๊ณ  ์„ค์น˜ (์ค‘๊ฐ„์— ๋‚˜์˜ค๋Š” ๋น„๋ฐ€๋ฒˆํ˜ธ๋Š” ๊นŒ๋จน์ง€ ์•Š๊ฒŒ syste..
ํ•™์›์—์„œ ์ž๋ฐ”๊ณผ์ •์„ ๋งˆ์ณ๊ฐ€์„œ ์•ž์œผ๋กœ ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋ฌธ์ œ๋ฅผ ์กฐ๊ธˆ์”ฉ์ด๋ผ๋„ ํ’€์–ด๋ณด๋ คํ•œ๋‹ค. ์ฒ˜์Œ ํ’€์–ด๋ณด๋Š” ๋ฌธ์ œ๋ผ ์‰ฌ์šด ๋‚œ์ด๋„๋กœ ๊ณจ๋ž๊ณ , ์ฝ”๋”ฉ๋„์žฅ ํ™ˆํŽ˜์ด์ง€์—์„œ ์ถœ์ œ๋œ ๋ฌธ์ œ๋ฅผ ๊ฐ€์ ธ์™”๋‹ค. ๋ฌธ์ œ ์ฃผ์–ด์ง„ ๋ฌธ์ž์—ด(๊ณต๋ฐฑ ์—†์ด ์‰ผํ‘œ๋กœ ๊ตฌ๋ถ„๋˜์–ด ์žˆ์Œ)์„ ๊ฐ€์ง€๊ณ  ์•„๋ž˜ ๋ฌธ์ œ์— ๋Œ€ํ•œ ํ”„๋กœ๊ทธ๋žจ์„ ์ž‘์„ฑํ•˜์„ธ์š”. ์ด์œ ๋•,์ด์žฌ์˜,๊ถŒ์ข…ํ‘œ,์ด์žฌ์˜,๋ฐ•๋ฏผํ˜ธ,๊ฐ•์ƒํฌ,์ด์žฌ์˜,๊น€์ง€์™„,์ตœ์Šนํ˜,์ด์„ฑ์—ฐ,๋ฐ•์˜์„œ,๋ฐ•๋ฏผํ˜ธ,์ „๊ฒฝํ—Œ,์†ก์ •ํ™˜,๊น€์žฌ์„ฑ,์ด์œ ๋•,์ „๊ฒฝํ—Œ 1.๊น€์”จ์™€ ์ด์”จ๋Š” ๊ฐ๊ฐ ๋ช‡ ๋ช… ์ธ๊ฐ€์š”? 2."์ด์žฌ์˜"์ด๋ž€ ์ด๋ฆ„์ด ๋ช‡ ๋ฒˆ ๋ฐ˜๋ณต๋˜๋‚˜์š”? 3.์ค‘๋ณต์„ ์ œ๊ฑฐํ•œ ์ด๋ฆ„์„ ์ถœ๋ ฅํ•˜์„ธ์š”. 4.์ค‘๋ณต์„ ์ œ๊ฑฐํ•œ ์ด๋ฆ„์„ ์˜ค๋ฆ„์ฐจ์ˆœ์œผ๋กœ ์ •๋ ฌํ•˜์—ฌ ์ถœ๋ ฅํ•˜์„ธ์š”. import java.util.ArrayList; import java.util.Collections; import java.util.H..
ํ•™์Šต ๋‚ด์šฉ - Collection : ์ˆ˜์ง‘ List: ๋ชฉ๋ก ArrayList ๋ฐฐ์—ด์ฒ˜๋Ÿผ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” ๋ฆฌ์ŠคํŠธ ์„ ํ˜•๊ตฌ์กฐ O-O-O-O-O ๊ฒ€์ƒ‰์†๋„๊ฐ€ ๋น ๋ฅด๋‹ค index๋กœ ์ ‘๊ทผํ•œ๋‹ค LinkedList ์ถ”๊ฐ€/์‚ญ์ œ ์†๋„๊ฐ€ ๋น ๋ฅด๋‹ค ArrayList arrlist = new ArrayList(); // ๊ธฐ๋ณธํ˜•์‹ //์ถ”๊ฐ€ --> .add(์ €์žฅ๊ฐ’) ๋ฅผ ํ†ตํ•ด ์ฐจ๋ก€๋Œ€๋กœ ๊ฐ’ ์ €์žฅ arrlist.add(111); Integer in = new Integer(222); arrlist.add(in); arrlist.add(new Integer(333)); int len = arrlist.size(); System.out.println("๋ชฉ๋ก์˜ ํฌ๊ธฐ " + len);// ๊ฒฐ๊ณผ : ๋ชฉ๋ก์˜ ํฌ๊ธฐ 3 for (int i = 0; i < ..
EastShine_
'๐Ÿ’ป ๊ฐœ๋ฐœ' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๊ธ€ ๋ชฉ๋ก (5 Page)