레이블이 oracle sga인 게시물을 표시합니다. 모든 게시물 표시
레이블이 oracle sga인 게시물을 표시합니다. 모든 게시물 표시

2013년 10월 13일 일요일

Spring3.x, Hibernate4연동하기]스프링3.2,하이버네이트4.2.3

1. 하이버네이트 다운로드
 다운로드
 www.hibernate.org (hibernate-4.2.3.Final.zip 사용)
 lib : 하이버네이트를 실행 시 필요한 JAR 파일
 project : 각종 소스 코드
 documentation : 문서들
 하이버네이트를 실행하기 위해서는 hibernate4.2.3.jar 파일 뿐 아니라 lib 폴더의 각종 jar 파일이 필요하다.
 물론 이클립스 하이버네이트 플러그인을 설치해도 된다. 현재 Eclipse INDIGO 까지 나와 있다.

2. 준비
 이클립스 ? Spring Project
hibernate4 및 spring 관련 라이브러리 추가
(하이버네이트4 의 경우 스프링 3,1 이상이 필요)
주) 스프링의 Template Project에서 hhibernate Template을 이용하여 하이버네이트 APP 작성가능하나 라이브러리 버전이 맞지 않아 hibernate4 예제와 연동 어려움
    

예제 테이블 작성
  create table myemp (
      empno number ,
      ename varchar2(10)
  )

 
 

3. MyEmp.java
package edu.onj.hibernate;
public class MyEmp {
private int empno;
private String ename;
 public MyEmp() {}
 public MyEmp(int empno, String ename) {
  this.empno = empno;    this.ename = ename;
 }
 public int getEmpno() { return empno;  }
 public void setEmpno(int empno) {this.empno = empno;}
 public String getEname() {
  return ename;
 }
 public void setEname(String ename) {
  this.ename = ename;
 }
}
 
 
4. MyempDao.java

package edu.onj.hibernate;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
@Repository
@Transactional(propagation=Propagation.REQUIRED)
public class MyEmpDao {
private SessionFactory sessionFactory;
private Session session;
public MyEmpDao() {}
//constructor injection(생성자 주입)
@Autowired
public MyEmpDao(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public Session getSession() {
return sessionFactory.getCurrentSession();
}
public void insertMyEmp(MyEmp myemp) {
getSession().save(myemp);
}
public void deleteMyEmp(int empno) {
getSession().delete(getMyEmpByEmpno(empno));
}
public MyEmp getMyEmpByEmpno(int empno) {
return (MyEmp)getSession().get(MyEmp.class, empno);
}
public void saveMyEmp(MyEmp myemp) {
getSession().update(myemp);
}
}
 
5. myemp.hbm.xml
<?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" >
    <hibernate-mapping>
    <class    name="edu.onj.hibernate.MyEmp"    table="MyEmp"    lazy="false">
        <id name="empno"  type="java.lang.Integer"   column="empno"  />
        <property  name="ename" type="java.lang.String"  column="ENAME" length="10"/>
    </class>
    </hibernate-mapping>
 
6. spring-hibernate.xml
 
<?xml version="1.0" encoding="UTF-8"?>
    <beans
        xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:util="http://www.springframework.org/schema/util"
        xmlns:aop="http://www.springframework.org/schema/aop"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:tx="http://www.springframework.org/schema/tx"
        xsi:schemaLocation=
        "http://www.springframework.org/schema/beans
         http://www.springframework.org/schema/beans/spring-beans.xsd
         http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
         http://www.springframework.org/schema/aop
         http://www.springframework.org/schema/context
         http://www.springframework.org/schema/context/spring-context-3.0.xsd
         http://www.springframework.org/schema/tx
         http://www.springframework.org/schema/tx/spring-tx.xsd
         http://www.springframework.org/schema/util
         http://www.springframework.org/schema/util/spring-util.xsd" >

<!-- Annotation 쓰기 위해서 -->
      <context:annotation-config />
      <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" >
        <property name="driverClassName"><value>oracle.jdbc.driver.OracleDriver</value></property>
        <property name="url"><value>jdbc:oracle:thin:@localhost:1521:onj</value></property>
        <property name="username"><value>scott</value></property>
        <property name="password"><value>tiger</value></property>
      </bean>
      <!-- Hibernate Session Factory 설정 -->
      <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource"><ref bean="dataSource"/></property>
        <property name="mappingResources">
          <list>
            <value>myemp.hbm.xml</value>
          </list>
        </property>
        <property name="hibernateProperties">
          <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
          </props>
        </property>
      </bean>
      <!-- 트랜잭션 -->
      <tx:annotation-driven transaction-manager="transactionManager" />
      <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
          <property name="sessionFactory" ref="sessionFactory" />
      </bean>
      <!-- MyEmpDAO autowiring  -->
      <bean id="myEmpDao" class="edu.onj.hibernate.MyEmpDao"> </bean>
   </beans>
  
  
7.    SpringHibernateExam.java

public class SpringHibernateExam {
public static void main(String[] args) {
ApplicationContext ctx = new ClassPathXmlApplicationContext("spring-hibernate.xml");
MyEmpDao myEmpDao = (MyEmpDao)ctx.getBean("myEmpDao");
try {
MyEmp myemp1 = new MyEmp(1, "1길동");
MyEmp myemp2 = new MyEmp(2, "2길동");
MyEmp myemp3 = new MyEmp(3, "3길동");
myEmpDao.insertMyEmp(myemp1);
myEmpDao.insertMyEmp(myemp2);
myEmpDao.deleteMyEmp(1);
myEmpDao.insertMyEmp(myemp3);
MyEmp emp1 = (MyEmp)myEmpDao.getMyEmpByEmpno(3);
System.out.println(emp1.getEmpno() + "::" + emp1.getEname());
myemp2.setEname("2가아니고4");
myEmpDao.saveMyEmp(myemp2);
MyEmp emp2 = (MyEmp)myEmpDao.getMyEmpByEmpno(2);
System.out.println(emp2.getEmpno() + "::" + emp2.getEname());
}
catch (HibernateException e)
        {             e.printStackTrace();         }
        finally        {                }
}
}
 
8. 결과
/*
SQL> select * from myemp;
EMPNO ENAME
---------- ----------
    2 2가아니고4
    3 3길동
*/
  
  
 
 

2013년 8월 10일 토요일

[ORACLEJAVA교육, 웹퍼블리싱, HTML5, jQuery실무교육]HTML5 개요

HTML5개요 입니다. 참고하세요~

오라클자바커뮤니티에서 설립한 오엔제이프로그래밍 실무교육센터
(오라클SQL, 튜닝, 힌트,자바프레임워크, 안드로이드, 아이폰, 닷넷 실무전문 강의)  


<video width="320height="240" autoplay controls poster="image.jpg">
  <!- mp4 : 사파리, IE9, 아이폰, 아이패드, 안드로이드, 윈도우7 폰버젼 -->
  <source src="video.mp4type="video/mp4">
  <!- WebM : 파이어폭스4, 오페라, 크롬 -->
  <source src="video.webmtype="video/webm">
  <!- ogv : 파이어폭스4 이전버젼 -->
  <source src="video.ogvtype="video/ogv">
</video>
 
5. 다양한 API 지원
 드래그 & 드랍 웹 콘텐츠들을 드래그 할 수 있는 기능 (모든 브라우져에서 지원하지 않음)
 애플리케이션 캐시
 오프라인 상태에서도 애플리케이션을 실행할 수 있도록 지원하는 기능
 웹스토리지
 쿠키처럼 클라이언트 쪽에 데이터를 저장할 수 있는 기능
 Indexed 데이터베이스
 클라이언트에 저장하는 데이터 베이스 기능
 웹 워커
 시간이 오래 걸리는 작업을 백그라운드로 실행하는 기능
 지오로케이션
 PC나 모바일 장치에서 현재 위치를 파악할 수 있게 해주는 기능

 
 
■ HTML5의 문제점

1. HTML5를 지원하지 않는 브라우져의 존재
  - IE6/7/8에서 미지원, IE9에서도 완벽하게 지원하지 않음
  - 2012년 1월 윈도우 XP 점유율은 47%로 앞으로 상당 기간 HTML5가 나아가는데 큰 걸림돌이 될 것으로 보임
    (윈도우 XP는 IE8 버젼까지만 설치가 가능하기 때문에 HTML5를 보기 위해서는 다른 브라우져 설치가 필요함)

2. 저작권 보호 문제 (개발소스, 동영상, 음악)

3. ActiveX의 보안성을 대체할 요소가 없음
  - 은행권, 공공기관에서 사용하는 ActiveX의 보안성을 대체할 요소가 없기 때문에 ActiveX의 사용은 당분간 계속될 것으로 보임
 
■ 브라우저 지원 현황
브라우저VerHTML5 검사 점수[2]
2012년 1월 6일
VerHTML5 검사 점수
2012년 5월 23일[3]
구글 크롬16.0373/47518400
모질라 파이어폭스10.0332/47512345
오페라11.60329/47511.60338
오페라12 알파344/47512.00385
애플 사파리5.1302/4755.1317
인터넷 익스플로러9141/4759138
인터넷 익스플로러10306/47510316
맥스톤--3.3.7437
 
 

2013년 8월 8일 목요일

[오라클자바커뮤니티강좌교육]JAVA instance, static class 변수

이번 강좌에서는 자바에서의 변수에 대해 알아 보도록 하죠...



오라클자바커뮤니티에서 설립한 오엔제이프로그래밍 실무교육센터
(오라클SQL, 튜닝, 힌트,자바프레임워크, 안드로이드, 아이폰, 닷넷 실무전문 강의)  




자바에서의 변수는 지역변수(local variables), 매개변수(parameters),클래스 범위에서 선언 한 인스턴스 변수(instance fields), 클래스 변수(class fields) 등으로 구분 할 수 있습니다. 물론 인스턴스 변수나 클래스변수나 전부 어떤 메소드(함수)안에서 선언되는 것이 아니라 메소드 밖에 선언되는 변수 입니다. 말이 틀리지만 그 쓰임새 또한 대단히 다르니 잘 아래의 내용을 발 봐두어야 합니다.

전 가끔 붕어빵 찍는 틀클래스로 비유하고 그 틀에 의해 찍혀 나오는 각각의 붕어(인스턴스)객체라고 비유 합니다. 붕어빵 찍는 클이 클래스라고 했으니 클래스 변수 붕어빵 찍는 틀과 관련이 있는 거죠... 즉 찍혀 나온 모든 붕어빵들이 공유하는 전역 변수로서 역할을 하며 또한 붕어를 만들어 내지 않아도 붕어빵 찍는 틀애 있는 것이니까 New 하지 않아도(붕어를 찍어 내지 않아도) 접근이 가능하죠... 즉 클래스 변수는 클래스이름.클래스변수명 으로 접근이 가능 한겁니다. 각각의 붕어를 찍어 낼때 팥의 양을 조절이 가능하다고 가정 할때 클래스변수가 아닌 인스턴스 변수팥의양을 둘 수가 있겠죠... 이건 붕어빵 찍는 틀(클래스)과 관련이 있는 변수가 아니라 찍혀 나온 붕어(인스턴스)들에 관련이 있는 변수 이므로 인스턴스 변수라고 하고 반드시 붕어를 찍어 낸 후(New 한 후) 접근이 가능한 변수가 되는 겁니다. 이해가 되시나요? 아래를 보시면서 다시 한번 정리하시기 바랍니다. 그래서 static이라는 키워드를 보는 순간 전역변수, 초기화가 한번만(붕어빵 찍는 틀과 관련이 있으므로), New 하지 안아도(붕어를 찍어 내지 않아도) 접근이 가능하며 즉 클래스이름.변수명... 잘 기억하시기 바랍니다.

클래스 변수

클래스의 인스턴스(객체)가 아니라 그것이 정의된 클래스와 연관된다.
static 한정자는 이 변수(필드)가 클래스필드 임을 의미
상수를 정의하는것이 클래스필드의 일반적인 사용이다.public static final double PI=3.14159;
정적필드의 복사본은 오직 한 개 존재하며 전역변수로 사용 된다.
같은 클래스 내부에서는 PI로 지칭되며 클래스 외부에서 해당 변수(필드)를 유일하게 지칭하기 위해서는 클래스명.PI로 인스턴스를 생성하지 않고도 직접 참조가 가능(물론 인스턴스를 만든 후 객체참조변수.PI형태의 참조도 가능하다.)


인스턴스 변수

static으로 선언되지 않은 모든 변수(필드)는 인스턴스 변수 입니다. public double r;
클래스의 인스턴스와 연관, 생성된 모든 객체는 자신만의
복사본을 가진다.
클래스 내부에서 이름 하나만으로 지칭된다
public double r;
public double area() {
return PI * r * r;
}
클래스 외부에서는 클래스를 인스턴스화한 객체.변수명 형
태로 사용한다. 인스턴스 필드(변수)의 값은 한객체를 다른
객체와 구분한다.
Circle c = new Circle(); c.r=2.0;
Circle c1 = new Circle(); c1.r=5.0;






2013년 8월 5일 월요일

[ORACLE SGA Tuning]DBMS_SHARED_POOL, Object KEEP

[ORACLE SGA Tuning]DBMS_SHARED_POOL, Object KEEP

오라클자바커뮤니티에서 설립한 오엔제이프로그래밍 실무교육센터
(오라클SQL, 튜닝, 힌트,자바프레임워크, 안드로이드, 아이폰, 닷넷 실무전문 강의) 
 www.onjprogramming.co.kr 




DBMS_SHARED_POOL을 이용한 KEEP

 Shared Poll에 크기가 큰 프로그램을 KEEP하기 위해서는 아래에 있는 것처럼 DBMS_SHARED_POOL Package를 이용 할 수 있습니다.

SQL> @C:\oracle\ora92\rdbms\admin\dbmspool.sql

패키지가 생성되었습니다.


권한이 부여되었습니다.


뷰가 생성되었습니다.


패키지 본문이 생성되었습니다.

SQL> @C:\oracle\ora92\rdbms\admin\prvtpool.plb

뷰가 생성되었습니다.


패키지 본문이 생성되었습니다.

SQL> grant execute on dbms_shared_pool to scott;

권한이 부여되었습니다.

Object를 KEEP하는 방법은 다음과 같습니다.

Procedure,Function,Package : exec dbms_shared_pool.keep(‘pname’,’p’)
Trigger : exec dbms_shared_pool.keep(‘tr_emp’,’r’)
Sequence : exec dbms_shared_pool.keep(‘seq_empno,’q’)
SQL문은 아래와 같은 방법으로 KEEP 합니다.

예를들어 select empno, ename, sal from emp where deptno = ‘20’ 라는 SQL문장을 Library Cache안의 Shared Cursor 부분에 KEEP하기 위해서는 아래처럼 하면 됩니다…

SQL> conn scott/tiger
연결되었습니다.

SQL> select empno, ename, sal from emp where deptno = 20;

    EMPNO ENAME            SAL
---------- ---------- ----------
      7369 SMITH            800
      7566 JONES            2975
      7788 SCOTT            3000
      7876 ADAMS            1100
      7902 FORD            3000

SQL> conn / as sysdba
연결되었습니다.

SQL> select address, hash_value from v$sqlarea
  2  where sql_text = 'select empno, ename, sal from emp where deptno = 20';

ADDRESS  HASH_VALUE
-------- ----------
7856AC4C 1137127237  <- 원하는 SQL문장에 대한 주소와 해시 값

아래 명령으로  KEEP 합니다.

SQL> exec dbms_shared_pool.keep('7856AC4C, 1137127237','c');

PL/SQL 처리가 정상적으로 완료되었습니다.

Object의 KEEP 상태는 다음으로 체크 가능 합니다.

SQL> select distinct name, sharable_mem, loads
  2  from v$db_object_cache
  3  where name like '%emp%'
  4  and kept = 'YES';

NAME                                      SHARABLE_MEM      LOADS
------------ ----------------------------------------------
select empno, ename, sal from emp where deptno = 20  1469          1

또는 exec dbms_shared_pool.sizes(0)로 확인 가능 합니다. 이 sizes라는 procedure는 제한된 사이크 이상의 keep된 Object를 나타내 줍니다.

SQL> set serveroutput on size 2000
SQL> exec dbms_shared_pool.sizes(0)  -> buffer overflow가 나더라도 pin시킬(KEEP할) SQL문장을 찾을 수는 있습니다.

각 Object를 Shared Pool에 유지하던 것을 해제 할 때는 아래의 unkeep 프로시저를 이용 합니다.

SQL> exec dbms_shared_pool.unkeep('7856AC4C, 1137127237','c');

PL/SQL 처리가 정상적으로 완료되었습니다.

SQL> select distinct name, sharable_mem, loads
  2  from v$db_object_cache
  3  where name like '%emp%'
4  and kept = 'YES';

결과가 없겠죠…


아래는 DBMS_SHARED_POOL.keep procedure 명셉니다… 메타링크 자료니 참고 하세요…

PROCEDURE:DBMS_SHARED_POOL.KEEP
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Version/s:  7.1+, 8.0, 8.1
See Also:  [NOTE:67537.1] The Purpose of DB Package Reference Articles
            [NOTE:67569.1] DBMS_SHARED_POOL Package Description
 
Specification:
  procedure keep(name varchar2, flag char DEFAULT 'P');
 
Description:
  Keep an object in the shared pool.  Once an object has been keeped in
    the shared pool, it is not subject to aging out of the pool.  This
    may be useful for certain semi-frequently used large objects since
    when large objects are brought into the shared pool, a larger
    number of other objects (much more than the size of the object 
    being brought in, may need to be aged out in order to create a
    contiguous area large enough.
    WARNING:  This procedure may not be supported in the future when
    and if automatic mechanisms are implemented to make this 
    unnecessary.
 
  Input arguments:
    name
      The name of the object to keep.  There are two kinds of objects:
      PL/SQL objects, triggers, sequences which are specified by name,
          and SQL cursor objects which are specified by a two-part number
      (indicating a location in the shared pool).  For example:
        dbms_shared_pool.keep('scott.hispackage')
      will keep package HISPACKAGE, owned by SCOTT.  The names for
      PL/SQL objects follows SQL rules for naming objects (i.e., 
      delimited identifiers, multi-byte names, etc. are allowed).
      A cursor can be keeped by
        dbms_shared_pool.keep('0034CDFF, 20348871')
      The complete hexadecimal address must be in the first 8 characters.
      The value for this identifier is the concatonation of the
      'address' and 'hash_value' columns from the v$sqlarea view.  This
      is displayed by the 'sizes' call above.
      Currently 'TABLE' and 'VIEW' objects may not be keeped.
    flag
      This is an optional parameter.  If the parameter is not specified,
        the package assumes that the first parameter is the name of a
        package/procedure/function and will resolve the name.  It can also
        be set to 'P' or 'p' to fully specify that the input is the name
        of a package/procedure/function.
       
        Other FLAG options are:
          'T' or 't'        to specify that the input is the name of a type.
          'R' or 'r'        to specify that the input is the name of a trigger 
          'Q' or 'q'        to specify that the input is the name of a sequence.
          other        In case the first argument is a cursor address and 
                        hash-value, the parameter should be set to any 
                        character except 'P','p','Q','q','R','r','T' or 't'.
 
  Exceptions:
    An exception will raised if the named object cannot be found.

2013년 8월 4일 일요일

Oracle SGA(Oracle System Global Area)

SGA는 DataBase Buffer Cache,Redo Log Buffer, Shared Pool등으로 구성된다. 
1.DataBase Buffer Cache 
- DataFile로 부터 읽어들인 Data Block의 복사본을 가지고 있습니다. 
- Cache내의 Buffer에는 수정되었지만 디스크에 기록되지 않은 Dirty Buffer와 
빈버퍼,고정된버퍼,아직 더티목록으로 이동되지 않은 더티목록등으로 구성되는 
LRU목록등이 있다. 
- Oracle은 사용자 프로세스가 빈버퍼를 찾지 못하고 버퍼의 임계점에 도달하면 
프로세스는 LRU목록 검색을 중지하고 Dirty Buffer를 Disk에 기록하도록 DBWR에 
신호를 보낸다. 
- 초기 Parameter DB_BLOCK_BUFFERS는 DB의 DataBase Buffer Cache의 Buffer수를 지 
정합니다. Cache의 Buffer는 하나의 Oracle Data Block과 동일하며,Cache는 제한된 
크기이므로 Cache가 가득찬후 Cache실패가 발생하면 Oracle은 Cache에 있는 Data를 
디스크에 기록한다. 
- size가 작으므로 발생 할 수 있는 현상은 빈번한 디스크 I/O이다. 크기는 db_block_buffers로 
지정하며 buffer의 갯수를 지정한다. 
  byte 산정은 db_block_buffers * db_block_size로 산출된다.        

2.Redo Log Buffer 
- DataBase의 변경사항 정보를 유지하는 SGA에 있는 원형 Buffer 
- BackGround 프로세스인 LGWR는 Redo Log Buffer를 디스크상에서 사용중인 Online 
Redo Log File Group에 기록한다. 
- Redo Log Buffer의 크기는 Parameter LOG_BUFFER로 결정한다 
큰 값을 가질경우 Log File의 I/O가 감소하며,트랜잭션이 길고 수가 많은 경우에 특히 더감소한다. 
기본크기는 OS DataBlock의 4배임. 

3.공유풀(Shared Pool) 
A. Library Cache 
- 공유 SQL영역, 전용SQL영역,PL/SQL Procedure와  Package, 잠금장치나 Library 
    Cache Handle과 같은 제어구조를 포함한다. 
  - 공유 SQL영역은 단일 SQL명령문에 대한 구문분석 트리와 실행계획을 가지는 영 
    역이며, 전용SQL영역은 바인드정보나 실행 시간 버퍼(SQL이 실행되는 동안 사용 
    되는 정보, Insert/Update/Delete보다 Select가 많음) 같은 데이터를 가지는 영역 
  - 전용SQL여역을 관리하는 것은 사용자 프로세스이고,사용자 프로세스가 할당할수 
    있는 전용SQL영역의 수는 OPEN_CURSORS(Default 50)로 제한 되지만 전용SQL 
    영역할당 또는 해제는 사용자가 사용하는 응용프로그램 도구에 의해 좌우됨 
B. Dictionary Cache 
- Data Dictionary(Table/View의 이름,Column이름과유현,Oracle사용자 권한)는 자주 
    Access되므로 메모리에 두개의 특별한 위치를 지정하여 Dicitonary  Data를 저장 

 - 공유풀에서 메모리 할당 및 재사용 
공유풀에 있는 항목은 수정된 LRU 알고리즘에 의해 지워질 때 까지 남아있다. 
Oracle은 공유풀을 확인하여 동일한 명령문이 공유풀에 있는지 확인한다. 
이때 같은 Query라도 대순자를 틀리게하여 Query하는 경우에는 틀린것으로 인식하여 
또다른 공유풀의 영역을 할당한다.(즉 SELECT * FROM EMP와 select * from emp는 다르게 인식) 
이렇게 함으로서 메모리를 절약하며,수행능력이 향상된다. 
- ANALYZE명령어를 사용하여 Table/Cluster/Index의 통계를 할경우 분석된 개체를 참조하는 
명령문을 포함하는 모든 공유 SQL영역이 공유풀에서 지워진다. 
- SGA의 크기는 Instance 시작시에 결정되며 대부분의 시스템에서 성능을 최적화 하려면 전체 
SGA의 크기가 실제 Memory 크기에 맞아야 한다.가상메모리를 사용하면 OS가 SGA의 일부를 
Page 하므로 시스템 성능이 급격히 떨어진다. 

- SGA의 크기에 영향을 주는 Parameter 
DB_BLOCK_SIZE : 하나의 Data Block과 DataBase Buffer크기를 Byte 단위로 나타낸 것 
DB_BLOCK_BUFFERS : DB_BLOCK_SIZE인 데이터베이스 Buffer수를 나타냄 
LOG_BUFFER : 리두로그 버퍼에 대한 할당된 바이트수 
SHARED_POOL_SIZE : 공유SQL영역과 PL/SQL명령문에 할당된 영역의 크기를 Byte 
                    단위로 나타낸 것 


[출처]오라클자바커뮤니티, 오엔제이프로그래밍
www.onjprogramming.co.kr