SQLD 17

오라클 NL Join, Sort Merge Join, Hash Join 특징 총정리

NL Join(Nested Loops Join) 수행 원리1) 다음은 NL Join의 수행 방식을 단계별로 나타낸 것입니다.① 선행 테이블에서 조건을 만족하는 첫 번째 행을 찾음 → 이때 선행 테이블에 주어진 조건을 만족하지 않는 경우 해당 데이터는 필터링 된다.② 선행 테이블의 조인 키를 가지고 후행 테이블에 조인 키가 존재하는지 찾으러 감 → 조인 시도③ 후행 테이블의 인덱스에 선행 테이블의 조인 키가 존재하는지 확인 → 선행 테이블의 조인 값이 후행 테이블에 존재하지 않으면 선행 테이블 데이터는 필터링 됨 (더 이상 조인 작업을 진행할 필요 없음)④ 인덱스에서 추출한 레코드 식별자를 이용하여 후행 테이블을 액세스 → 후행 테이블에 주어진 조건까지 모두 만족하면 해당 행을 추출버퍼에 넣음. ⑤ ~ ⑪..

Database 2020.10.18

SQLD 합격 후기(공부 방법, 참고도서 등)

SQLD 시험 결과가 나와서 합격 후기 및 공부 방법, 참고도서, 시험 Tip에 대해 공유해보려고 합니다.시험 볼 때는 80~90점 예상했는데, 이게 웬걸.. SQLD 자격 준비 이유 및 소개가장 큰 이유는 웹개발자로써 회사에서 오라클(Oracle)을 사용하기 때문이었습니다. 대학생 시절 개인 공부할때는 MySQL만 사용했었는데...오라클을 사용한다니 DB Query를 짜더라도 뭔가 제대로 알고 만들어야겠다는 생각이 들었어요. 그냥 단순히 쿼리를 찍어내는 것보다 더 재밌게 고민하면서 짤 수 있지 않을까 하는 기대도 했구요ㅎ 종종 IT에서는 자격증이 필요없다? 는 말을 누군가 주위에서 하곤 했는데, 잘모르겠고 SQLD는 개인적으로 정말 많은 도움이 된 것 같아요. SQLP는 얼마나 큰 도움이 될까요. 뭐 ..

일상 2020.10.06

오라클 PL/SQL 프로시저(Procedure) 특징 및 예제

프로시저(Procedure)의 특징 개발자가 자주 실행해야하는 특정 작업을 필요할 때 호출하기위해 절차적인 언어를 이용하여 작성한 이름이 있는 프로그램 모듈(Block)을 의미한다. - 매개 변수를 받을 수 있는 PL/SQL BLOCK 이다. (PL/SQL 블록이란?)- 프로시저 내의 변수는 Scalar변수라고 해서 임시 데이터 1개만 저장할 수 있는 변수이며, 모든 형태의 데이터 유형 지정 가능.- PL/SQL의 대입연산자는 ‘ := ’이다. (↔ T-SQL은 일반적인 ‘ = ’이다)- PL/SQL에서 사용하는 프로시저 내의 SELECT문장은 반드시 결과 값이 있어야 하며, 그 결과는 반드시 1개여야 한다. 조회결과가 없거나 2개 이상인 경우에는 에러가 발생(T-SQL은 결과값없어도 상관없음)한다. 그..

Database 2020.09.28

오라클 PL/SQL과 블록(Block) 구조 및 특징

Oracle 에서의 블록(Block) 구조 및프로시저(Procedure), 사용자 정의 함수(User Defined Function), 트리거(Trigger) 비교 총정리 PL/SQL(Oracle's Procedural Language extension to SQL, 절차형 SQL)이란??1) 응용 프로그램에서의 데이터베이스 처리 성능을 향상시키기 위해 SQL문장에서 변수정의, 조건처리(IF), 반복처리(LOOP, WHILE, FOR) 등을 지원하며, 오라클 자체에 내장되어 있는(오라클에서 지원하는) Procedure Language이다. 2) PL/SQL을 이용하여 다양한 저장 모듈(Stored Module)을 개발할 수 있다.※저장 모듈: PL/SQL문장을 데이터베이스 서버에 저장하여 사용자와 애플리..

Database 2020.09.26

Oracle 윈도우 함수(WINDOW FUNCTION)/집계함수(AGGREGATE FUNCTION)

윈도우 함수(Window Function) 기본 문법① Oracle에서의 분석 & 순위 함수인 윈도우 함수는 크게 5가지 그룹으로 분류된다.② 윈도우 함수 사용 시 OVER문구가 키워드로 필수 포함된다.③ WINDOW 함수는 다른 함수와는 달리 중첩(NEST)해서 사용하지는 못하지만, 서브쿼리(Sub Query)에서는 사용할 수 있다.  1) Window Function SyntaxSELECT WINDOW_FUNCTION(argument) OVER( [partition by 칼럼] [order by 절] [window 절] )FROM 테이블명;  윈도우 함수(Window Function) 종류1) 그룹 내 순위 관련 함수① RANK : 동일한 값에 대해서는 동일한 순위를 부여 예) 1 → 2 → 2 → ..

Database 2020.09.23

[Oracle] 오라클 뷰(View) 특징 총정리

뷰(View)의 중요 포인트 10가지사용자에게 접근이 허용된 자료만을 제한적으로 보여주기 위해 하나 이상의 기본 테이블로부터 유도된, 이름을 가지는 가상 테이블(Virtual Table)이다. 뷰는 저장장치 내에 물리적으로 존재하지 않지만 사용자에게 있는 것처럼 간주된다. 1) Table은 실제 데이터를 가지고 있지만, View는 단지 ‘뷰 정의’만을 가지고 있다.2) 질의문에서 뷰를 사용하면 이 ‘뷰 정의’를 참조해서 DBMS내부적으로 질의를 재구성하여 질의를 수행한다. 따라서, View는 실제 데이터를 가지고 있지는 않지만 테이블이 수행하는 역할을 하기 때문에, 가상 테이블(Virtual Table) 이라고도 불리는 것.3) 뷰의 정의는 변경할 수 없다. (ALTER VIEW문을 사용할 수 없음, 필..

Database 2020.09.21

[Oracle] IN, EXISTS, NOT IN, NOT EXISTS 특징 및 비교

다중 행(Multi Row) 서브쿼리 IN과 EXISTS 실행 순서 및 특징1) IN : 실제 존재(일치)하는 데이터들의 모든 값까지 확인.① SubQuery를 먼저 실행하여 출력되는 그에 대한 모든 row가져옴(따라서 사실 IN뒤의 괄호안에는 서브쿼리 이외에도 직접 요소 값을 적어줄 수 있음)② 이후에는 MainQuery에서 하나의 row를 가져옴.③ 그 row의 값이 ①에서 가져온 IN 이하의 요소들에 포함(일치)되어 있는지를 체크하고, SubQuery의 요소들 중 하나라도 일치한다면 그 row를 출력④ ②번~③번 과정 반복하면서 결과 출력.  2) EXISTS : 단지 해당 row가 존재하는지만 확인하고, 더 이상 수행되지 않음.① MainQuery를 먼저 실행하여 출력되는 상위 row가져옴.② 해..

Database 2020.09.18

Oracle 서브쿼리(Sub Query) 사용법 & 예제

서브쿼리(Sub Query) 개념1) SQL문 내에 쓰인 SELECT 문을 의미하며, 이때 바깥에 있는 SQL문을 메인 쿼리(Main Query)라 부른다.2) MainQuery 안에 포함된 종속적인 관계이기 때문에 논리적인 실행순서는 항상 MainQuery에서 읽혀진 데이터에 대해 SubQuery에서 해당 조건이 만족하지를 확인하는 방식으로 수행되어야 한다. 그러나 실제 SubQuery의 실행순서는 상황에 따라 달라질 수 있음. → SubQuery의 검색된 결과 값이 MainQuery에 사용될 때의 SubQuery는 MainQuery 실행 전에 실행됨.서브쿼리 종류설명비연관(Un-Correlated) 서브쿼리서브쿼리가 메인쿼리 칼럼을 가지고 있지 않는 형태의 서브쿼리를 의미한다. 메인쿼리에 값(서브쿼리..

Database 2020.09.17

계층형 쿼리(Hierarchical Query) 개념 및 실행 순서 상세 정리

Oracle 계층형 쿼리(Hierarchical Query)란?테이블에 계층적인 순서로 표현해야 하는 데이터가 존재하는 경우 데이터를 조회하기 위해서 계층형 질의(Hierarchical Query)를 사용한다. 계층형 데이터란 동일 테이블에 계층적으로 상위와 하위 데이터가 포함된 데이터를 말한다. 예를 들어, 사원 테이블에서는 사원들 사이에 상위 사원(관리자 or 직속상사)과 하위 사원 관계가 존재하고 조직 테이블에서는 조직들 사이에 상위 조직과 하위 조직 관계가 존재한다. 엔티티를 순환관계 데이터 모델로 설계할 경우 계층형 데이터가 발생한다. 순환관계 데이터 모델의 예로는 조직, 사원, 메뉴 등이 있다.그리고 이러한 계층형 데이터를 기본적인 SQL문을 사용하여 계층 관계를 표현하는것은 불가능하며, 재귀..

Database 2020.09.16

집합 연산자(union, union all, intersect, except)

집합 연산자(Set Operator)여러 개의 질의의 결과를 연결(결합)하여 하나로 결과로 만드는 방식을 의미한다. (즉, 여러 개의 SELECT문을 연결하는 것)  1) 일반 집합 연산자① union : 여러 SQL문의 결과에 대한 합집합, union키워드로 구현.결과에서 중복된 행은 하나의 행으로 만듬. → 중복을 없애기 위한 정렬 작업으로 시스템 부하↑ ↔ union all키워드는 중복을 제외하지 않고 그대로 결합. 즉, 단순히 쿼리결과를 합침.② intersection : 여러 SQL문의 결과에 대한 교집합, intersect키워드로 구현.③ difference : 여러 SQL문의 결과에 대한 차집합. 대다수의 벤더는 EXCEPT를, Oracle은 MINUS키워드를 사용. (SQL표준은 EXCEP..

Database 2020.09.15