본문 바로가기

데이터베이스26

12. 스칼라 서브쿼리 서브쿼리는 select, from, where중 어디에 들어가는가에 따라 이름이 달라진다. 그 중 select 절에 붙는 서브쿼리를 스칼라 서브쿼리라고 한다. 스칼라 서브쿼리의 동작은 다음과 같다 1. 메인쿼리 실행 2. 스칼라 서브쿼리용 데이터를 메모리에 띄움 3. 값 도출 4. 다시 메인쿼리 실행 이 작업을 메인쿼리가 끝날 때 까지 실행한다. from절에 내리게 될 경우 서브쿼리가 우선적으로 실행되기 때문에 값이 달라질 수 있다. 따라서, 스칼라 서브쿼리의 경우 메모리에 미리 값을 띄워두고 메인쿼리를 반복하기 때문에 훨씬 빠르게 찾을 수 있다. 그러나, 띄운 메모리와 다른 값을 찾게 될 경우는 다시 하드웨어에서 값을 찾아 메모리에 다시 띄우는 일을 해야하기 때문에 느려질 우려가 있으며, Driven .. 2020. 4. 8.
데이터 검색 기법 데이터를 검색할 때는 1. 램을 거치거나, 2. 디스크에 접근하거나 해야한다. 램은 전기적 신호로 작동되기 때문에 가져오는 것도, 연산속도도 빠르지만, 하드디스크는 물리적인 도구라 램보다 가져오는 것이 느리다. 따라서 디스크 접근을 줄이는 것이 검색속도를 향상 시킬 수 있는 방법이다. 하드디스크에 접근하는 것을 디스크 접근(I/O)라고 하는데, 이는 데이터 INPUT 과 OUTPUT의 약자이다. 데이터 접근을 줄일 수 있는 방법은 1. 캐시 메모리 검색 기법 2. 시퀀셜 엑세스 기법 3. 랜덤 엑세스 기법이다 있다. 1. 캐시 메모리 검색 기법 캐시 메모리는 아주 작은 메모리(1~12M)이다. 속도가 빠른 대신 가격이 비싸다. 캐시 메모리라는 말이 포괄적인데, 검색이 하드 디스크까지 가기 전에 메모리에서.. 2020. 4. 2.
11. SUB QUERY 이전부터 많이 썼던 서브쿼리는, 하나 이상의 조건을 한 문단에 처리하기 위해 사용하는 기법이다. 쿼리 안에 다른 쿼리를 담는 형태를 의미한다. 바깥에 있는 쿼리를 메인 쿼리, 내부에 있는 쿼리를 서브 쿼리라고 한다. 서브쿼리의 간단한 예시는 다음과 같다. SELECT * FROM EMP WHERE SAL>(SELECT SAL FROM EMP WHERE ENAME = 'SMITH'); 매우 익숙한 모습이다. 서브쿼리는 주의할 점이 있다. 다음과 같은 쿼리를 보자. SELECT * FROM EMP WHERE SAL= (SELECT SAL FROM EMP WHERE JOB = 'MANAGER'); 이 쿼리를 실행시켜보면 다음과 같은 오류가 뜬다. 내부에 있는 쿼리만 실행시켜보면, 3개 행이 실행되어 있음을 볼.. 2020. 4. 2.
10. DML DML은 데이터를 넣고, 빼고, 변경하는 명령어를 알아보도록 한다. 1. INSERT 데이터를 테이블 내부에 넣는 명령어이다. 문법 : INSERT INTO 테이블명(컬럼명) VALUES(넣고싶은 데이터) 예시: INSERT INTO PROFESSOR(PROFNO, NAME, ID, POSITION, PAY, HIREDATE) VALUES(5001, '제임스', 'LOVE_ME','정교수',500,'14/10/23'); 이 때, 날짜를 입력할 때 주의할 점이 있다. 오라클 18C는 날짜의 데이터 타입 형태 YY/MM/DD 든 YY-MM-DD든 어떤 형태로 넣어도 자동으로 넣어주는데, 낮은 버전의 오라클을 쓸 경우에는 날짜의 데이터 타입을 확인하고 넣도록 한다. INSERT INTO DEPT2 VALUES.. 2020. 4. 2.
반응형