2014년 6월 25일 수요일

[SQL튜닝,실무SQL교육,오라클자바커뮤니티]SQL WHERE 와 HAVING, SQL학원교육,오라클교육

[SQL튜닝,실무SQL교육,오라클자바커뮤니티]SQL WHERE  HAVING, SQL학원교육,오라클교육
 
 
 
예문을 통해 WHERE를 쓰는 경우와 HAVING을 쓰는 경우의 차이에 대해 알아 보도록 하겠습니다.
 
n  실습을 위한 테이블을 만들자.
 
create table myemp1
(empno number not null primary key,
 ename varchar2(100),
 deptno number,
 addr   varchar2(100),
 sal    number
 )
 
-- 실습을 위해 myemp1 2000만건 만들자.
DECLARE
          v_c NUMBER := 1;
BEGIN
 
          WHILE (v_c <= 10000000) LOOP
                insert into myemp1 values ( v_c, '홍길동'||v_c, mod(v_c, 5), '서울'||v_c, mod(v_c, 1000000));
                v_c := v_c + 1;
                insert into myemp1 values ( v_c, '다길동'||v_c, mod(v_c, 5), '부산'||v_c, mod(v_c, 1000000));
                v_c := v_c + 1;
                insert into myemp1 values ( v_c, '나길동'||v_c, mod(v_c, 5), '대구'||v_c, mod(v_c, 1000000));
                v_c := v_c + 1;
                insert into myemp1 values ( v_c, '나길동'||v_c, mod(v_c, 5), '광주'||v_c, mod(v_c, 1000000));
                v_c := v_c + 1;
          END LOOP;
          commit;
END;
 
create index idx_myemp1_deptno on myemp1(deptno)
 
 
 
SQL> set autotrace on explain
SQL> set timing on
 
아래 질의는 MYEMP1 테이블의 데이터를 DEPTNO 별로 그룹핑 하는데DEPTNO 1번인 부서원들의 급여 합을 구하는 질의 입니다. (myemp1에는 dept인덱스가 걸려 있습니다)
 
 10초 가까지 걸렸다.
 
SQL> select deptno, avg(sal)
  2    from myemp1
  3   group by deptno
  4   having deptno  = 1;
 
    DEPTNO   AVG(SAL)
---------- ----------
1       499998.5
 
   : 00:00:09.89
--------------------------------------
| Id  | Operation           | Name   |
--------------------------------------
|   0 | SELECT STATEMENT    |        |
|*  1 |  FILTER             |        |
|   2 |   SORT GROUP BY     |        |
|   3 |    TABLE ACCESS FULL| MYEMP1 |
 
 
 
이 경우에는 Table FULL SCAN한 후 GROUP BY를 한 후 deptno 1인 것을 찾기 위해 FILTER를 사용 했습니다.
 
 
이 번에는 having 대신 where절을 이용하여 같은 결과를 만들어 보도록 하겠습니다.
(현재 deptno 값은 0,1,2,3,4 5가지 값이 있어 분포도가 20%)
 
17초 정도 결렸다아마 데이터가 많아서 그런 모양이다테스트 해보라.
 
SQL>  select deptno, avg(sal)
  2     from myemp1
  3   where deptno =1
  4  group by deptno;
 
    DEPTNO   AVG(SAL)
---------- ----------
         1   499998.5
 
   : 00:00:17.29
 
Execution Plan
----------------------------------------------------------
|   0 | SELECT STATEMENT             |                   |
|   1 |  SORT GROUP BY               |                   |
|   2 |   TABLE ACCESS BY INDEX ROWID| MYEMP1            |
|*  3 |    INDEX RANGE SCAN          | IDX_MYEMP1_DEPTNO |
----------------------------------------------------------
 
이 경우에는 DEPTNO의 인덱스를 이용하여 부분 검색을 통해 deptno 10인 데이터를 꺼낸 후 GROUP BY를 시켜 count(*)를 구하였습니다.
 
 
이번에는 위 SQL문을 hash_sj(해시세미조인)을 시켜보자절반 정도 빨라진다.
 
SQL> select deptno, avg(sal)
  2    from myemp1
  3  where deptno =1
  4   group by deptno;
 
    DEPTNO   AVG(SAL)
---------- ----------
         1   499998.5
 
   : 00:00:08.43
 
Execution Plan
----------------------------------------------------------
|   0 | SELECT STATEMENT     |        |  2339K|    58M| 16991   (1)|
|   1 |  SORT GROUP BY NOSORT|        |  2339K|    58M| 16991   (1)|
|*  2 |   TABLE ACCESS FULL  | MYEMP1 |  2339K|    58M| 16991  (1)|
 
 
 
아래처럼 집계된 값이 어떠하다라고 비교 할려면 반드시 having구만을 사용해야 합니다.
 
 
SQL>  select deptno, avg(sal)
  2     from myemp1
  3    group by deptno
  4    having avg(sal) > 300000;
 
    DEPTNO   AVG(SAL)
---------- ----------
         0   499997.5
         1   499998.5
         2   499999.5
         3   500000.5
         4   500001.5
 
   00:00:09.64
 
Execution Plan
-----------------------------------------------
Plan hash value: 2438610968
 
--------------------------------------
| Id  | Operation           | Name   |
--------------------------------------
|   0 | SELECT STATEMENT    |        |
|*  1 |  FILTER             |        |
|   2 |   SORT GROUP BY     |        |
|   3 |    TABLE ACCESS FULL| MYEMP1 |


--------------------------------------

오라클자바커뮤니티교육센터, 개발자전문교육, 개인80%환급
www.oraclejavacommunity.com


평일주간(9:30~18:10) 개강
(6/30)[기업100%환급]PL/SQL,ORACLE HINT,TUNING
(6/30)[기업100%환급]안드로이드개발자과정
(6/30)[기업100%환급]SQL기초에서 Schema Object까지
(7/07)[기업100%환급]C#4.0,WinForm,ADO.NET프로그래밍
(7/07)[기업100%환급]Spring ,MyBatis,Hibernate실무과정
(7/07)[기업100%환급]자바기초에서 JDBC, Servlet/JSP까지
(7/07)[채용예정교육]오라클자바개발잘하는신입뽑기프로젝트,교육전취업확정

평일야간(19:00~21:50) 개강
(6/26)SQL초보에서실전전문가까지
(7/01)안드로이드개발자과정
(7/01)닷넷(C#,Network,ADO.NET,ASP.NET)마스터과정
(7/02)Spring3.X, MyBatis, Hibernate실무과정
(7/02)자바웹(JSP,Spring,MyBatis,XPlatform)프로젝트과정
(7/02)JAVA,Network&WEB&Framework(자바기초에서웹스프링까지)
(7/03)웹퍼블리싱 마스터
(7/15)MyBatis3.X, Hibernate4.X ORM실무과정
(7/22)자바기초에서JSP,Ajax,jQuery,Spring3.2,MyBatis까지

주말(10:00~17:50) 개강
(6/28)Spring3.X, MyBatis, Hibernate실무과정
(6/28)안드로이드개발자과정
(6/28)실무예제로 배워보는 jQuery(개발자/디자이너를위한)
(6/28)자바기초에서JSP,Ajax,jQuery,Spring3.2,MyBatis까지
(7/05)SQL초보에서 Schema Object까지
(7/12)자바웹(JSP,Spring,MyBatis,XPlatform)프로젝트과정
(7/12)MyBatis3.X, Hibernate4.X ORM실무과정
(7/12)개발자를위한PLSQL,SQL튜닝,힌트
(7/13)C#,ASP.NET마스터

주말저녁(18:30~22:20) 개강
(6/28)JAVA,Network&WEB&Framework
(6/28)SQL기초에서실무까지

댓글 없음:

댓글 쓰기