실행환경 오라클11g 옵티마이저 모드는 CBO(Cost Based Optimizer, all_rows)
ordered 힌트는 from절에 나타나는 순서대로 조인을 하라는 힌트이며, from절의 처음나타나는 테이블이
드라이빙 테이블이 되며, leading 힌트는 해당 테이블을 먼저 드라이빙 하라는 의미의 힌트이다.
use_nl : 중첩루프조인을 하라는 힌트
use_hash : hash 조인을 하라는 힌트
myemp1 테이블은 2000만건 이며, deptno 컬럼에 인덱스가 생성되어 있다.
-- 시간:27초, mydemp1(deptno인덱스 Fast Full Scan)이 드라이빙 테이블
select /*+ ordered use_nl(d) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
-- ordered 와 같이 써야함, use_nl 힌트는 무시됨
select /*+ use_nl(d) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
-- ordered 와 같이 써야함, use_nl 힌트는 무시됨
select /*+ use_nl(e) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
--use_nl의 인자를 두개 걸면 중첩루프걸림, 드라이빙 테이블은 오라클이 알아서 작은 테이블(MYDEPT1)로
select /*+ use_nl(d e) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
--use_nl의 인자를 두개 걸면 중첩루프걸림, 드라이빙 테이블은 오라클이 알아서 작은 테이블(MYDEPT1)로
select /*+ use_nl(e d) */
count(d.dname)
from mydept1 d, myemp1 e where e.deptno = d.deptno;
-- 아래는 ordered 무시됨, use_nl인자가 2개인것은 use_nl(d) and use_nl(d)의 shortcut, 둘중 맞는것으로 해석함
select /*+ ordered use_nl(d e) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
-- 아래는 ordered 무시됨, use_nl인자가 2개인것은 use_nl(d) and use_nl(d)의 shortcut, 둘중 맞는것으로 해석함
select /*+ ordered use_nl(e d) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
-- 7.4초, mydept1이 드라이빙 테이블
-- form절에 처음 나타나는 mydept1이 드라이빙 테이블, myemp1은 비드라이빙 테이블이며
-- use_nl의 인자로 들어가야 한다.
select /*+ ordered use_nl(e) */
count(d.dname)
from mydept1 d, myemp1 e where e.deptno = d.deptno;
--17초, myemp1(deptno인덱스 Fast Full Scan)이 드라이빙 테이블
--inner table(비드라이빙테이블)은 mydept1이 된다.
select /*+ ordered use_hash(d) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno
-- 9초, mydept1이 드라이빙 테이블, 비드라이빙 테이블 myemp1이 use_hash인자로
select /*+ ordered use_hash(e) */
count(d.dname)
from mydept1 d, myemp1 e where e.deptno = d.deptno;
-- 19초, use_merge는 드라이빙 테이블이 중요치않다. 소트 후 머지병합하므로...
select /*+ use_merge(d e) */
count(d.dname)
from mydept1 d, myemp1 e where e.deptno = d.deptno;
-- mydept1가 드라이빙 테이블이며 중첩 루프 조인한다.(use_nl의 인자는 비드라이빙 테이블)
select /*+ leading(d e) use_nl(e) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
-- myemp1이 드라이빙 테이블이며 중첩루프 조인한다.(use_nl의 인자는 비드라이빙 테이블)
select /*+ leading(e d) use_nl(d) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
-- mydept1가 드라이빙 테이블, 조인방법에 대해 명시안했으니 CBO 모드에서는 해시조인한다.
select /*+ leading(d e) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
-- myemp1이 드라이빙 테이블, 조인방법에 대해 명시안했으니 CBO 모드에서는 해시조인한다.
select /*+ leading(e d) */
count(d.dname)
from myemp1 e, mydept1 d where e.deptno = d.deptno;
오라클자바커뮤니티교육센터, 개발자전문교육, 개인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기초에서실무까지
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기초에서실무까지
댓글 없음:
댓글 쓰기