11g에서 impdp를 사용시 발생하는 에러

원래의 segment 절을 사용용 할 수 없어 발생 

 TRANSFORM=SEGMENT_ATTRIBUTES:N 

옵션을 추가 하여 해결


예는 아래...

Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

Master table "SYSTEM"."SYS_IMPORT_SCHEMA_01" successfully loaded/unloaded

Starting "SYSTEM"."SYS_IMPORT_SCHEMA_01":  system/******** dumpfile=PUMP_DIR:TLO.dmp logfile=PUMP_DIR:TLO.log schemas=HR, SCOTT, SH, TLO remap_tablespace=EXAMPLE:USERS 

Processing object type SCHEMA_EXPORT/USER

Processing object type SCHEMA_EXPORT/SYSTEM_GRANT

Processing object type SCHEMA_EXPORT/ROLE_GRANT

Processing object type SCHEMA_EXPORT/DEFAULT_ROLE

Processing object type SCHEMA_EXPORT/TABLESPACE_QUOTA

Processing object type SCHEMA_EXPORT/PRE_SCHEMA/PROCACT_SCHEMA

Processing object type SCHEMA_EXPORT/SEQUENCE/SEQUENCE

Processing object type SCHEMA_EXPORT/TABLE/TABLE

ORA-39083: Object type TABLE:"SH"."SALES" failed to create with error:

ORA-14102: only one LOGGING or NOLOGGING clause may be specified

Failing sql is:

CREATE TABLE "SH"."SALES" ("PROD_ID" NUMBER NOT NULL ENABLE, "CUST_ID" NUMBER NOT NULL ENABLE, "TIME_ID" DATE NOT NULL ENABLE, "CHANNEL_ID" NUMBER NOT NULL ENABLE, "PROMO_ID" NUMBER NOT NULL ENABLE, "QUANTITY_SOLD" NUMBER(10,2) NOT NULL ENABLE, "AMOUNT_SOLD" NUMBER(10,2) NOT NULL ENABLE) PCTFREE 5 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS  NOLOGGING  S

ORA-39083: Object type TABLE:"SH"."COSTS" failed to create with error:

ORA-14102: only one LOGGING or NOLOGGING clause may be specified

Failing sql is:

CREATE TABLE "SH"."COSTS" ("PROD_ID" NUMBER NOT NULL ENABLE, "TIME_ID" DATE NOT NULL ENABLE, "PROMO_ID" NUMBER NOT NULL ENABLE, "CHANNEL_ID" NUMBER NOT NULL ENABLE, "UNIT_COST" NUMBER(10,2) NOT NULL ENABLE, "UNIT_PRICE" NUMBER(10,2) NOT NULL ENABLE) PCTFREE 5 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS  NOLOGGING  STORAGE( BUFFER_POOL DEFAULT FLASH_CACHE

ORA-39083: Object type TABLE:"TLO"."SALES" failed to create with error:

ORA-14460: only one COMPRESS or NOCOMPRESS clause may be specified

Failing sql is:

CREATE TABLE "TLO"."SALES" ("PROD_ID" NUMBER NOT NULL ENABLE, "CUST_ID" NUMBER NOT NULL ENABLE, "TIME_ID" DATE NOT NULL ENABLE, "CHANNEL_ID" NUMBER NOT NULL ENABLE, "PROMO_ID" NUMBER NOT NULL ENABLE, "QUANTITY_SOLD" NUMBER(10,2) NOT NULL ENABLE, "AMOUNT_SOLD" NUMBER(10,2) NOT NULL ENABLE) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255  STORAGE( BUFFER_PO

Processing object type SCHEMA_EXPORT/TABLE/TABLE_DATA

. . imported "SH"."CUSTOMERS"                            9.853 MB   55500 rows

. . imported "TLO"."CUSTOMERS"                           9.853 MB   55500 rows

. . imported "SH"."SUPPLEMENTARY_DEMOGRAPHICS"           697.3 KB    4500 rows



'OraclE' 카테고리의 다른 글

session 레벨 sql trace  (0) 2014.07.16
테이블 rename시 dependency는?  (0) 2014.07.07
oracle hr schema 생성  (0) 2014.05.21
rman 백업 확인  (0) 2014.03.27
[펌] DBMS_XPLAN.DISPLAY_CURSOR  (0) 2014.03.24

 

hr.sql

오라클 HR schema 생성

conn sys/oracle as sysdba

CREATE USER hr IDENTIFIED BY hr
default tablespace users;

create role hr_main;

grant CREATE VIEW, CREATE TABLE, ALTER SESSION, CREATE CLUSTER,
CREATE SESSION, CREATE SYNONYM, CREATE SEQUENCE, CREATE DATABASE LINK,
CREATE TYPE,  CREATE TRIGGER,  CREATE OPERATOR , CREATE PROCEDURE, QUERY REWRITE
to hr_main;

grant hr_main to hr;

ALTER USER hr QUOTA unlimited ON users;

GRANT execute ON sys.dbms_stats TO hr;

CONNECT hr/hr

ALTER SESSION SET NLS_LANGUAGE=American;
ALTER SESSION SET NLS_TERRITORY=America;

CREATE TABLE regions
    ( region_id      NUMBER CONSTRAINT  reg_id_pk PRIMARY KEY,
      region_name    VARCHAR2(25)
    );

CREATE TABLE countries
    ( country_id      CHAR(2) CONSTRAINT country_c_id_pk PRIMARY KEY ,
      country_name    VARCHAR2(40),
      region_id       NUMBER CONSTRAINT countr_reg_fk
               REFERENCES regions(region_id)
    )
    ORGANIZATION INDEX;

CREATE TABLE locations
    ( location_id    NUMBER(4) CONSTRAINT loc_id_pk PRIMARY KEY,
      street_address VARCHAR2(40),
      postal_code    VARCHAR2(12),
      city           VARCHAR2(30) CONSTRAINT loc_city_nn  NOT NULL,
      state_province VARCHAR2(25),
      country_id     CHAR(2) CONSTRAINT loc_c_id_fk
            REFERENCES countries(country_id)
    ) ;

CREATE TABLE departments
    ( department_id    NUMBER(4) CONSTRAINT dept_id_pk PRIMARY KEY,
      department_name  VARCHAR2(30) CONSTRAINT  dept_name_nn  NOT NULL,
      manager_id       NUMBER(6),
      location_id      NUMBER(4) CONSTRAINT dept_loc_fk
                REFERENCES locations (location_id)
    ) ;

CREATE TABLE jobs
    ( job_id         VARCHAR2(10) CONSTRAINT job_id_pk PRIMARY KEY,
      job_title      VARCHAR2(35) CONSTRAINT     job_title_nn  NOT NULL,
      min_salary     NUMBER(6),
      max_salary     NUMBER(6)
    ) ;

create table job_grades
 ( grade_level varchar2(3) CONSTRAINT job_gra_level_pk PRIMARY KEY,
   lowest_sal number,
   highest_sal number);

CREATE TABLE employees
    ( employee_id    NUMBER(6) CONSTRAINT emp_emp_id_pk PRIMARY KEY ,
      first_name     VARCHAR2(20),
      last_name      VARCHAR2(25) CONSTRAINT emp_last_name_nn  NOT NULL,
      email          VARCHAR2(25) CONSTRAINT emp_email_uk UNIQUE,
      phone_number   VARCHAR2(20),
      hire_date      DATE     CONSTRAINT  emp_hire_date_nn  NOT NULL,
      job_id         VARCHAR2(10) CONSTRAINT  emp_job_fk  REFERENCES jobs(job_id),
      salary         NUMBER(8,2)  CONSTRAINT  emp_salary_min CHECK (salary > 0),
      commission_pct NUMBER(2,2),
      manager_id     NUMBER(6)    CONSTRAINT  emp_manager_fk REFERENCES employees(employee_id),
      department_id  NUMBER(4) CONSTRAINT emp_dept_fk REFERENCES departments(department_id)
    ) ;

ALTER TABLE departments
ADD (CONSTRAINT dept_mgr_fk FOREIGN KEY(manager_id) REFERENCES employees (employee_id)
    ) ;

CREATE TABLE job_history
    ( employee_id   NUMBER(6) CONSTRAINT    jhist_employee_nn  NOT NULL,
      start_date    DATE  CONSTRAINT    jhist_start_date_nn  NOT NULL,
      end_date      DATE CONSTRAINT    jhist_end_date_nn  NOT NULL,
      job_id        VARCHAR2(10)  CONSTRAINT    jhist_job_nn  NOT NULL,
      department_id NUMBER(4),
      CONSTRAINT jhist_emp_id_st_date_pk PRIMARY KEY (employee_id, start_date),
      CONSTRAINT jhist_date_interval     CHECK (end_date > start_date),
      CONSTRAINT jhist_job_fk FOREIGN KEY (job_id) REFERENCES jobs(job_id),
      CONSTRAINT jhist_emp_fk FOREIGN KEY (employee_id) REFERENCES employees(employee_id),
      CONSTRAINT jhist_dept_fk FOREIGN KEY (department_id) REFERENCES departments(department_id)
    ) ;

CREATE SEQUENCE locations_seq
 START WITH     3300
 INCREMENT BY   100
 MAXVALUE       9900
 NOCACHE
 NOCYCLE;

CREATE SEQUENCE departments_seq
 START WITH     280
 INCREMENT BY   10
 MAXVALUE       9990
 NOCACHE
 NOCYCLE;

CREATE SEQUENCE employees_seq
 START WITH     207
 INCREMENT BY   1
 NOCACHE
 NOCYCLE;


CREATE OR REPLACE VIEW emp_details_view
  (employee_id,
   job_id,
   manager_id,
   department_id,
   location_id,
   country_id,
   first_name,
   last_name,
   salary,
   commission_pct,
   department_name,
   job_title,
   city,
   state_province,
   country_name,
   region_name)
AS SELECT
  e.employee_id,
  e.job_id,
  e.manager_id,
  e.department_id,
  d.location_id,
  l.country_id,
  e.first_name,
  e.last_name,
  e.salary,
  e.commission_pct,
  d.department_name,
  j.job_title,
  l.city,
  l.state_province,
  c.country_name,
  r.region_name
FROM
  employees e,
  departments d,
  jobs j,
  locations l,
  countries c,
  regions r
WHERE e.department_id = d.department_id
  AND d.location_id = l.location_id
  AND l.country_id = c.country_id
  AND c.region_id = r.region_id
  AND j.job_id = e.job_id
WITH READ ONLY;

COMMIT;

SET VERIFY OFF
ALTER SESSION SET NLS_LANGUAGE=American;

 

INSERT INTO regions VALUES
        ( 1
        , 'Europe'
        );

INSERT INTO regions VALUES
        ( 2
        , 'Americas'
        );

INSERT INTO regions VALUES
        ( 3
        , 'Asia'
        );

INSERT INTO regions VALUES
        ( 4
        , 'Middle East and Africa'
        );

 


INSERT INTO countries VALUES
        ( 'US'
        , 'United States of America'
        , 2
        );

INSERT INTO countries VALUES
        ( 'CA'
        , 'Canada'
        , 2
        );

INSERT INTO countries VALUES
        ( 'UK'
        , 'United Kingdom'
        , 1
        );

INSERT INTO countries VALUES
        ( 'DE'
        , 'Germany'
        , 1
        );

 

INSERT INTO locations VALUES
        ( 1400
        , '2014 Jabberwocky Rd'
        , '26192'
        , 'Southlake'
        , 'Texas'
        , 'US'
        );

INSERT INTO locations VALUES
        ( 1500
        , '2011 Interiors Blvd'
        , '99236'
        , 'South San Francisco'
        , 'California'
        , 'US'
        );

INSERT INTO locations VALUES
        ( 1700
        , '2004 Charade Rd'
        , '98199'
        , 'Seattle'
        , 'Washington'
        , 'US'
        );

INSERT INTO locations VALUES
        ( 1800
        , '147 Spadina Ave'
        , 'M5V 2L7'
        , 'Toronto'
        , 'Ontario'
        , 'CA'
        );


INSERT INTO locations VALUES
        ( 2500
        , 'Magdalen Centre, The Oxford Science Park'
        , 'OX9 9ZB'
        , 'Oxford'
        , 'Oxford'
        , 'UK'
        );


ALTER TABLE departments
  DISABLE CONSTRAINT dept_mgr_fk;

INSERT INTO departments VALUES
        ( 10
        , 'Administration'
        , 200
        , 1700
        );

INSERT INTO departments VALUES
        ( 20
        , 'Marketing'
        , 201
        , 1800
        );


INSERT INTO departments VALUES
        ( 50
        , 'Shipping'
        , 124
        , 1500
        );

INSERT INTO departments VALUES
        ( 60
        , 'IT'
        , 103
        , 1400
        );

INSERT INTO departments VALUES
        ( 80
        , 'Sales'
        , 149
        , 2500
        );

INSERT INTO departments VALUES
        ( 90
        , 'Executive'
        , 100
        , 1700
        );


INSERT INTO departments VALUES
        ( 110
        , 'Accounting'
        , 205
        , 1700
        );


INSERT INTO departments VALUES
        ( 190
        , 'Contracting'
        , NULL
        , 1700
        );

INSERT INTO jobs VALUES
        ( 'AD_PRES'
        , 'President'
        , 20000
        , 40000
        );

INSERT INTO jobs VALUES
        ( 'AD_VP'
        , 'Administration Vice President'
        , 15000
        , 30000
        );

INSERT INTO jobs VALUES
        ( 'AD_ASST'
        , 'Administration Assistant'
        , 3000
        , 6000
        );


INSERT INTO jobs VALUES
        ( 'AC_MGR'
        , 'Accounting Manager'
        , 8200
        , 16000
        );

INSERT INTO jobs VALUES
        ( 'AC_ACCOUNT'
        , 'Public Accountant'
        , 4200
        , 9000
        );
INSERT INTO jobs VALUES
        ( 'SA_MAN'
        , 'Sales Manager'
        , 10000
        , 20000
        );

INSERT INTO jobs VALUES
        ( 'SA_REP'
        , 'Sales Representative'
        , 6000
        , 12000
        );


INSERT INTO jobs VALUES
        ( 'ST_MAN'
        , 'Stock Manager'
        , 5500
        , 8500
        );

INSERT INTO jobs VALUES
        ( 'ST_CLERK'
        , 'Stock Clerk'
        , 2000
        , 5000
        );


INSERT INTO jobs VALUES
        ( 'IT_PROG'
        , 'Programmer'
        , 4000
        , 10000
        );

INSERT INTO jobs VALUES
        ( 'MK_MAN'
        , 'Marketing Manager'
        , 9000
        , 15000
        );

INSERT INTO jobs VALUES
        ( 'MK_REP'
        , 'Marketing Representative'
        , 4000
        , 9000
        );


INSERT INTO employees VALUES
        ( 100
        , 'Steven'
        , 'King'
        , 'SKING'
        , '515.123.4567'
        , TO_DATE('17-JUN-1987', 'dd-MON-yyyy')
        , 'AD_PRES'
        , 24000
        , NULL
        , NULL
        , 90
        );

INSERT INTO employees VALUES
        ( 101
        , 'Neena'
        , 'Kochhar'
        , 'NKOCHHAR'
        , '515.123.4568'
        , TO_DATE('21-SEP-1989', 'dd-MON-yyyy')
        , 'AD_VP'
        , 17000
        , NULL
        , 100
        , 90
        );

INSERT INTO employees VALUES
        ( 102
        , 'Lex'
        , 'De Haan'
        , 'LDEHAAN'
        , '515.123.4569'
        , TO_DATE('13-JAN-1993', 'dd-MON-yyyy')
        , 'AD_VP'
        , 17000
        , NULL
        , 100
        , 90
        );

INSERT INTO employees VALUES
        ( 103
        , 'Alexander'
        , 'Hunold'
        , 'AHUNOLD'
        , '590.423.4567'
        , TO_DATE('03-JAN-1990', 'dd-MON-yyyy')
        , 'IT_PROG'
        , 9000
        , NULL
        , 102
        , 60
        );

INSERT INTO employees VALUES
        ( 104
        , 'Bruce'
        , 'Ernst'
        , 'BERNST'
        , '590.423.4568'
        , TO_DATE('21-MAY-1991', 'dd-MON-yyyy')
        , 'IT_PROG'
        , 6000
        , NULL
        , 103
        , 60
        );

 

INSERT INTO employees VALUES
        ( 107
        , 'Diana'
        , 'Lorentz'
        , 'DLORENTZ'
        , '590.423.5567'
        , TO_DATE('07-FEB-1999', 'dd-MON-yyyy')
        , 'IT_PROG'
        , 4200
        , NULL
        , 103
        , 60
        );


INSERT INTO employees VALUES
        ( 124
        , 'Kevin'
        , 'Mourgos'
        , 'KMOURGOS'
        , '650.123.5234'
        , TO_DATE('16-NOV-1999', 'dd-MON-yyyy')
        , 'ST_MAN'
        , 5800
        , NULL
        , 100
        , 50
        );


INSERT INTO employees VALUES
        ( 141
        , 'Trenna'
        , 'Rajs'
        , 'TRAJS'
        , '650.121.8009'
        , TO_DATE('17-OCT-1995', 'dd-MON-yyyy')
        , 'ST_CLERK'
        , 3500
        , NULL
        , 124
        , 50
        );

INSERT INTO employees VALUES
        ( 142
        , 'Curtis'
        , 'Davies'
        , 'CDAVIES'
        , '650.121.2994'
        , TO_DATE('29-JAN-1997', 'dd-MON-yyyy')
        , 'ST_CLERK'
        , 3100
        , NULL
        , 124
        , 50
        );

INSERT INTO employees VALUES
        ( 143
        , 'Randall'
        , 'Matos'
        , 'RMATOS'
        , '650.121.2874'
        , TO_DATE('15-MAR-1998', 'dd-MON-yyyy')
        , 'ST_CLERK'
        , 2600
        , NULL
        , 124
        , 50
        );

INSERT INTO employees VALUES
        ( 144
        , 'Peter'
        , 'Vargas'
        , 'PVARGAS'
        , '650.121.2004'
        , TO_DATE('09-JUL-1998', 'dd-MON-yyyy')
        , 'ST_CLERK'
        , 2500
        , NULL
        , 124
        , 50
        );

 

INSERT INTO employees VALUES
        ( 149
        , 'Eleni'
        , 'Zlotkey'
        , 'EZLOTKEY'
        , '011.44.1344.429018'
        , TO_DATE('29-JAN-2000', 'dd-MON-yyyy')
        , 'SA_MAN'
        , 10500
        , .2
        , 100
        , 80
        );


INSERT INTO employees VALUES
        ( 174
        , 'Ellen'
        , 'Abel'
        , 'EABEL'
        , '011.44.1644.429267'
        , TO_DATE('11-MAY-1996', 'dd-MON-yyyy')
        , 'SA_REP'
        , 11000
        , .30
        , 149
        , 80
        );


INSERT INTO employees VALUES
        ( 176
        , 'Jonathon'
        , 'Taylor'
        , 'JTAYLOR'
        , '011.44.1644.429265'
        , TO_DATE('24-MAR-1998', 'dd-MON-yyyy')
        , 'SA_REP'
        , 8600
        , .20
        , 149
        , 80
        );


INSERT INTO employees VALUES
        ( 178
        , 'Kimberely'
        , 'Grant'
        , 'KGRANT'
        , '011.44.1644.429263'
        , TO_DATE('24-MAY-1999', 'dd-MON-yyyy')
        , 'SA_REP'
        , 7000
        , .15
        , 149
        , NULL
        );


INSERT INTO employees VALUES
        ( 200
        , 'Jennifer'
        , 'Whalen'
        , 'JWHALEN'
        , '515.123.4444'
        , TO_DATE('17-SEP-1987', 'dd-MON-yyyy')
        , 'AD_ASST'
        , 4400
        , NULL
        , 101
        , 10
        );

INSERT INTO employees VALUES
        ( 201
        , 'Michael'
        , 'Hartstein'
        , 'MHARTSTE'
        , '515.123.5555'
        , TO_DATE('17-FEB-1996', 'dd-MON-yyyy')
        , 'MK_MAN'
        , 13000
        , NULL
        , 100
        , 20
        );

INSERT INTO employees VALUES
        ( 202
        , 'Pat'
        , 'Fay'
        , 'PFAY'
        , '603.123.6666'
        , TO_DATE('17-AUG-1997', 'dd-MON-yyyy')
        , 'MK_REP'
        , 6000
        , NULL
        , 201
        , 20
        );


INSERT INTO employees VALUES
        ( 205
        , 'Shelley'
        , 'Higgins'
        , 'SHIGGINS'
        , '515.123.8080'
        , TO_DATE('07-JUN-1994', 'dd-MON-yyyy')
        , 'AC_MGR'
        , 12000
        , NULL
        , 101
        , 110
        );

INSERT INTO employees VALUES
        ( 206
        , 'William'
        , 'Gietz'
        , 'WGIETZ'
        , '515.123.8181'
        , TO_DATE('07-JUN-1994', 'dd-MON-yyyy')
        , 'AC_ACCOUNT'
        , 8300
        , NULL
        , 205
        , 110
        );

insert into job_grades
values('A',1000, 2999);

insert into job_grades
values('B',3000, 5999);

insert into job_grades
values('C',6000, 9999);

insert into job_grades
values('D',10000, 14999);

insert into job_grades
values('E',15000, 24999);

insert into job_grades
values('F',25000, 40000);


INSERT INTO job_history
VALUES (102
       , TO_DATE('13-JAN-1993', 'dd-MON-yyyy')
       , TO_DATE('24-JUL-1998', 'dd-MON-yyyy')
       , 'IT_PROG'
       , 60);

INSERT INTO job_history
VALUES (101
       , TO_DATE('21-SEP-1989', 'dd-MON-yyyy')
       , TO_DATE('27-OCT-1993', 'dd-MON-yyyy')
       , 'AC_ACCOUNT'
       , 110);

INSERT INTO job_history
VALUES (101
       , TO_DATE('28-OCT-1993', 'dd-MON-yyyy')
       , TO_DATE('15-MAR-1997', 'dd-MON-yyyy')
       , 'AC_MGR'
       , 110);

INSERT INTO job_history
VALUES (201
       , TO_DATE('17-FEB-1996', 'dd-MON-yyyy')
       , TO_DATE('19-DEC-1999', 'dd-MON-yyyy')
       , 'MK_REP'
       , 20);


INSERT INTO job_history
VALUES  (200
        , TO_DATE('17-SEP-1987', 'dd-MON-yyyy')
        , TO_DATE('17-JUN-1993', 'dd-MON-yyyy')
        , 'AD_ASST'
        , 90
        );

INSERT INTO job_history
VALUES  (176
        , TO_DATE('24-MAR-1998', 'dd-MON-yyyy')
        , TO_DATE('31-DEC-1998', 'dd-MON-yyyy')
        , 'SA_REP'
        , 80
        );

INSERT INTO job_history
VALUES  (176
        , TO_DATE('01-JAN-1999', 'dd-MON-yyyy')
        , TO_DATE('31-DEC-1999', 'dd-MON-yyyy')
        , 'SA_MAN'
        , 80
        );

INSERT INTO job_history
VALUES  (200
        , TO_DATE('01-JUL-1994', 'dd-MON-yyyy')
        , TO_DATE('31-DEC-1998', 'dd-MON-yyyy')
        , 'AC_ACCOUNT'
        , 90
        );

ALTER TABLE departments
  ENABLE CONSTRAINT dept_mgr_fk;

COMMIT;

CREATE INDEX emp_department_ix
       ON employees (department_id);

CREATE INDEX emp_job_ix
       ON employees (job_id);

CREATE INDEX emp_manager_ix
       ON employees (manager_id);

CREATE INDEX emp_name_ix
       ON employees (last_name, first_name);

CREATE INDEX dept_location_ix
       ON departments (location_id);

CREATE INDEX jhist_job_ix
       ON job_history (job_id);

CREATE INDEX jhist_employee_ix
       ON job_history (employee_id);

CREATE INDEX jhist_department_ix
       ON job_history (department_id);

CREATE INDEX loc_city_ix
       ON locations (city);

CREATE INDEX loc_state_province_ix
       ON locations (state_province);

CREATE INDEX loc_country_ix
       ON locations (country_id);

COMMIT;

CREATE OR REPLACE PROCEDURE secure_dml
IS
BEGIN
  IF TO_CHAR (SYSDATE, 'HH24:MI') NOT BETWEEN '08:00' AND '18:00'
        OR TO_CHAR (SYSDATE, 'DY') IN ('SAT', 'SUN') THEN
 RAISE_APPLICATION_ERROR (-20205,
  'You may only make changes during normal office hours');
  END IF;
END secure_dml;
/

CREATE OR REPLACE TRIGGER secure_employees
  BEFORE INSERT OR UPDATE OR DELETE ON employees
BEGIN
  secure_dml;
END secure_employees;
/

ALTER TRIGGER secure_employees DISABLE;

REM **************************************************************************
REM procedure to add a row to the JOB_HISTORY table and row trigger
REM to call the procedure when data is updated in the job_id or
REM department_id columns in the EMPLOYEES table:

CREATE OR REPLACE PROCEDURE add_job_history
  (  p_emp_id          job_history.employee_id%type
   , p_start_date      job_history.start_date%type
   , p_end_date        job_history.end_date%type
   , p_job_id          job_history.job_id%type
   , p_department_id   job_history.department_id%type
   )
IS
BEGIN
  INSERT INTO job_history (employee_id, start_date, end_date,
                           job_id, department_id)
    VALUES(p_emp_id, p_start_date, p_end_date, p_job_id, p_department_id);
END add_job_history;
/

CREATE OR REPLACE TRIGGER update_job_history
  AFTER UPDATE OF job_id, department_id ON employees
  FOR EACH ROW
BEGIN
  add_job_history(:old.employee_id, :old.hire_date, sysdate,
                  :old.job_id, :old.department_id);
END;
/

COMMIT;
COMMENT ON TABLE regions
IS 'Regions table that contains region numbers and names. Contains 4 rows; references with the Countries table.'

COMMENT ON COLUMN regions.region_id
IS 'Primary key of regions table.'

COMMENT ON COLUMN regions.region_name
IS 'Names of regions. Locations are in the countries of these regions.'

COMMENT ON TABLE locations
IS 'Locations table that contains specific address of a specific office,
warehouse, and/or production site of a company. Does not store addresses /
locations of customers. Contains 23 rows; references with the
departments and countries tables. ';

COMMENT ON COLUMN locations.location_id
IS 'Primary key of locations table';

COMMENT ON COLUMN locations.street_address
IS 'Street address of an office, warehouse, or production site of a company.
Contains building number and street name';

COMMENT ON COLUMN locations.postal_code
IS 'Postal code of the location of an office, warehouse, or production site
of a company. ';

COMMENT ON COLUMN locations.city
IS 'A not null column that shows city where an office, warehouse, or
production site of a company is located. ';

COMMENT ON COLUMN locations.state_province
IS 'State or Province where an office, warehouse, or production site of a
company is located.';

COMMENT ON COLUMN locations.country_id
IS 'Country where an office, warehouse, or production site of a company is
located. Foreign key to country_id column of the countries table.';


REM *********************************************

COMMENT ON TABLE departments
IS 'Departments table that shows details of departments where employees
work. Contains 27 rows; references with locations, employees, and job_history tables.';

COMMENT ON COLUMN departments.department_id
IS 'Primary key column of departments table.';

COMMENT ON COLUMN departments.department_name
IS 'A not null column that shows name of a department. Administration,
Marketing, Purchasing, Human Resources, Shipping, IT, Executive, Public
Relations, Sales, Finance, and Accounting. ';

COMMENT ON COLUMN departments.manager_id
IS 'Manager_id of a department. Foreign key to employee_id column of employees table. The manager_id column of the employee table references this column.';

COMMENT ON COLUMN departments.location_id
IS 'Location id where a department is located. Foreign key to location_id column of locations table.';


REM *********************************************

COMMENT ON TABLE job_history
IS 'Table that stores job history of the employees. If an employee
changes departments within the job or changes jobs within the department,
new rows get inserted into this table with old job information of the
employee. Contains a complex primary key: employee_id+start_date.
Contains 25 rows. References with jobs, employees, and departments tables.';

COMMENT ON COLUMN job_history.employee_id
IS 'A not null column in the complex primary key employee_id+start_date.
Foreign key to employee_id column of the employee table';

COMMENT ON COLUMN job_history.start_date
IS 'A not null column in the complex primary key employee_id+start_date.
Must be less than the end_date of the job_history table. (enforced by
constraint jhist_date_interval)';

COMMENT ON COLUMN job_history.end_date
IS 'Last day of the employee in this job role. A not null column. Must be
greater than the start_date of the job_history table.
(enforced by constraint jhist_date_interval)';

COMMENT ON COLUMN job_history.job_id
IS 'Job role in which the employee worked in the past; foreign key to
job_id column in the jobs table. A not null column.';

COMMENT ON COLUMN job_history.department_id
IS 'Department id in which the employee worked in the past; foreign key to deparment_id column in the departments table';


REM *********************************************

COMMENT ON TABLE countries
IS 'country table. Contains 25 rows. References with locations table.';

COMMENT ON COLUMN countries.country_id
IS 'Primary key of countries table.';

COMMENT ON COLUMN countries.country_name
IS 'Country name';

COMMENT ON COLUMN countries.region_id
IS 'Region ID for the country. Foreign key to region_id column in the departments table.';

REM *********************************************

COMMENT ON TABLE jobs
IS 'jobs table with job titles and salary ranges. Contains 19 rows.
References with employees and job_history table.';

COMMENT ON COLUMN jobs.job_id
IS 'Primary key of jobs table.';

COMMENT ON COLUMN jobs.job_title
IS 'A not null column that shows job title, e.g. AD_VP, FI_ACCOUNTANT';

COMMENT ON COLUMN jobs.min_salary
IS 'Minimum salary for a job title.';

COMMENT ON COLUMN jobs.max_salary
IS 'Maximum salary for a job title';

REM *********************************************

COMMENT ON TABLE employees
IS 'employees table. Contains 107 rows. References with departments,
jobs, job_history tables. Contains a self reference.';

COMMENT ON COLUMN employees.employee_id
IS 'Primary key of employees table.';

COMMENT ON COLUMN employees.first_name
IS 'First name of the employee. A not null column.';

COMMENT ON COLUMN employees.last_name
IS 'Last name of the employee. A not null column.';

COMMENT ON COLUMN employees.email
IS 'Email id of the employee';

COMMENT ON COLUMN employees.phone_number
IS 'Phone number of the employee; includes country code and area code';

COMMENT ON COLUMN employees.hire_date
IS 'Date when the employee started on this job. A not null column.';

COMMENT ON COLUMN employees.job_id
IS 'Current job of the employee; foreign key to job_id column of the
jobs table. A not null column.';

COMMENT ON COLUMN employees.salary
IS 'Monthly salary of the employee. Must be greater
than zero (enforced by constraint emp_salary_min)';

COMMENT ON COLUMN employees.commission_pct
IS 'Commission percentage of the employee; Only employees in sales
department elgible for commission percentage';

COMMENT ON COLUMN employees.manager_id
IS 'Manager id of the employee; has same domain as manager_id in
departments table. Foreign key to employee_id column of employees table.
(useful for reflexive joins and CONNECT BY query)';

COMMENT ON COLUMN employees.department_id
IS 'Department id where employee works; foreign key to department_id
column of the departments table';

COMMIT;
EXECUTE dbms_stats.gather_table_stats ('HR','COUNTRIES');
EXECUTE dbms_stats.gather_table_stats ('HR','DEPARTMENTS');
EXECUTE dbms_stats.gather_table_stats ('HR','EMPLOYEES');
EXECUTE dbms_stats.gather_table_stats ('HR','JOBS');
EXECUTE dbms_stats.gather_table_stats ('HR','JOB_GRADES');
EXECUTE dbms_stats.gather_table_stats ('HR','JOB_HISTORY');
EXECUTE dbms_stats.gather_table_stats ('HR','LOCATIONS');
EXECUTE dbms_stats.gather_table_stats ('HR','REGIONS');

COMMIT;

spool off

rman 백업 확인 방법

 

○ LIST 명령
  RMAN> sql "alter session set nls_date_format=''yyyy-mm-dd HH24:MI:SS''";
        시간 확인
  RMAN> LIST BACKUP OF DATABASE;
  RMAN> LIST BACKUPSET OF DATABASE;
  RMAN> LIST BACKUP OF DATAFILE '/dev/rdata06' ;
         해당 datafile에 대한 backupset 백업만 보여줌
  RMAN> LIST COPY  OF DATAFILE '/dev/rdata06' ;
         해당 datafile에 대한 copy 백업
  RMAN> LIST BACKUP OF TABLESPACE USERS;
  RMAN> LIST BACKUP OF CONTROLFILE;
  RMAN> LIST BACKUP OF SPFILE;
  RMAN> list backup of archivelog all;
  RMAN> list backup of archivelog from scn 11894542  until scn 14063527;
  RMAN> list backup of archivelog from sequence 6  until  sequence 10 thread 2;

 

○ REPORT 명령
  RMAN> report need backup;
        현재 백업 설정과 비교하였을 시 필요한 백업은 없는지 확인
  RMAN> report need backup redundancy 3;        

 

○ Copy 명령어

RMAN > copy datafile '/dev/rdata06' to '/data_move/kkonti/copy/user01.dbf' ;

 

 

※ RMAN 에서 LIST 명령으로 확인이 불가능 하거나 불편할 경우 SQL에서 직접 확인 가능

 alter session set nls_date_format='YYYY/MM/DD HH24:MI:SS';

 

 col operation for a10

 col status for a25

SELECT OPERATION, OBJECT_TYPE, STATUS, MBYTES_PROCESSED, START_TIME, END_TIME

FROM v$RMAN_STATUS

ORDER BY START_TIME;

 

 

 

[출처] http://bysql.net/index.php?document_srl=18350&mid=w201102TA

오타 많네요. 오타 수정 완료.

 

** 실행계획 중요 **

이유 :  Query Transformation의 ?수행 전 / 후 의 실행 계획을 비교 하기 때문이다.

TOOL : 일반적으로 10046 Event Trace + tkprof

=> 10046 Event Trace + tkprof  무엇인가.?

trace : explain 보다 더 세밀하게 실행 정보를 가지고 있는 툴.

tkporf : trace 설정 후 실행 결과 파일

10046 event 가 갖지 못 한 장점

1.query block name / object alias : 쿼리 블럭 정보

2.outline data : 오라클 내부 ( internal ) hint

3. predicate information : Access 조건 및 조인 조건 , Filer 조건

4.Column Projection Information: Operation id 별로 select 된 컬럼 정보

5. format : 자신에게 맞는 format 설정이 자유로움

 

이런 이유로 우리는 DBMS_EPLAN.DISPLY_CURSOR / DBMS_XPAN.DISPLAY 사용 할 것이다.

=> DBMS_XPLAN 패키지란?

  DBMS_XPLAN 패키지는 EXPLAIN PLAN 구문보다 확장된 정보를 볼 수 있다.

  Oracle 9i에서 소개되었으며 Version Up에 따라 기능이 추가 되었다. 10g부터는 실행계획은 물론 Row Source별 수행 통계까지 출력 가능 하다

DBMS_EPLAN.DISPLY_CURSOR / DBMS_XPAN.DISPLAY  는 DBMS_XPLAN 패키지 function 중의 일부이다.

 

1) 사용법

 GATHER_PLAN_STATISTICS 힌트를 사용하면 SQL_ID 대입하지 않고 실행 계획을 볼수 있다.

** GATHER_PLAN_STATISTICS 란?

GATHER_PLAN_STATISTICS 힌트는 "Row source execution" 정보를 활성화한다.
Row source execution 이란 Execute Plan에서 보는 Row수의 예측 값이 아닌 실제 실행 과정에서 추출된 Row 수를 보여주는 것을 의미한다.

실행 쿼리 예 )

SELECT /*+GATHER_P:AN_STATISTICS*/

*

FROM

(SELECT e.*

FROM employee e

WHERE e.department_id = 50

ODER BY e.employee_id)

WHERE ROWNUM <= 100;

위 sql문 실행 후 연이어 다음 Query 실행 한다

 

SELECT *

FROM TABLE( DBMS_XPLAN.DISPLAY_CURSOR (null,null,'advanced allstats last'));

-- null, null 값은 가장 최근에 실행된 쿼리를 의미한다. 만일 특정 쿼리를 지정하고 싶다면 SQL ID와 Child Number를 주면 된다.

'advanced allstats last' 은 가장 많은 정보를 나타내는 옵션이다.

 

결과는 다음과 같다.

 --------------------------------------------------------------------------------------------------------------------------------
| Id  | Operation                      | Name              | E-Rows |E-Bytes| Cost (%CPU)| E-Time   |  OMem |  1Mem | Used-Mem |
--------------------------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT               |                   |        |       |     4 (100)|          |       |       |          |
|*  1 |  COUNT STOPKEY                 |                   |        |       |            |          |       |       |          |
|   2 |   VIEW                         |                   |     45 |  5985 |     4  (25)| 00:00:01 |       |       |          |
|*  3 |    SORT ORDER BY STOPKEY       |                   |     45 |  3105 |     4  (25)| 00:00:01 |  6144 |  6144 | 6144  (0)|
|   4 |     TABLE ACCESS BY INDEX ROWID| EMPLOYEE          |     45 |  3105 |     3   (0)| 00:00:01 |       |       |          |
|*  5 |      INDEX RANGE SCAN          | EMP_DEPARTMENT_IX |     45 |       |     1   (0)| 00:00:01 |       |       |          |
--------------------------------------------------------------------------------------------------------------------------------
 

 

 

** 쿼리 실행 결과 설명 **

1) Basics 항목

id : 각 operation Id / * 가 달려있는 경우는 predicate information 에 access 및 filter 에 관한 정보를 표시

Operation : 각각 실행되는 job

Name : Operation 의 엑세스 하는 테이블 및 인덱스

 

2) Query Optimizer Estimations 항목 ( 옵티마이저의 예상치 )

E-rows  : 각 Operation이 끝났을 때 return되는 건수

E-bytes : 각 Operation 이 return 한 byte 수

E-Temp : 각 Operation 이  Temporary Space 를 사용한 양

Cost(%CPU) : 각 Operation 의 Cost.( 괄호 안의 내용은 CPU Cost 의 백분율임 이 값은 Child Operation 의 Cost 를 합친 누적 치임 )

E-Time :  수행 시간

=> 위의 모든 리스트는 예상치를 나타내는 것이다.

 

3) Runtime statistics 항목 ( 실제 수행 시간 및 실제수행 건수 )

Starts : 각 Operation 을 반복 수행한 건수 ( nested loop join 이라면 조인을 시도한 횟수가 나타남)

A-Rows : 각 Operation이 Return 한 건수

A-Time : 실제 실행 시간 0.01 초 단위 까지. 나타남 => child Operation의 A-time을 합친 값

 

4) I/O statistics ( I/O 관련하여 READ / WRITE 한 Block 수 )

Buffers : 각 Operation이 Memory 에서 읽은 수

Reads :  각 Operation이 Disk 에서 Read 한 Block 수 ( 예지 plan엔 나타내지 않음 )

Writes  : 각 Operation이 Disk 에 Write 한 Block 수  ( 예지 plan엔 나타내지 않음 )

 

5) Memory utilization Statistics ( hash 작업이나 sort 작업 시 사용한 메모리 통계 )

OMem : Optimal Execution 에 필요한 Memory

1Mem : One-pass Execution 에 필요한 Memory

O/1 M : 각 Operation 이 실행한 Optimal/One-pass /Multipass 횟수가 순서대로 표시됨.( 예지에서는 나타나지 않음 )

Used - Mem : 마지막 실행 시 사용한 PGA Memory

Used - Tmp : 마지막 실행 시 메모리가 부족하여 Temporary Space 를 대신 사용할 때 나타남. 보이는 값에 1024 를 곱해야 합. 예를 들어 32K 로 나타나면 32MB를 의미함 ( 예지에서는 나타나지 않음 )

Mas-tmp : 메모리가 부족하여 Temporary Space 를 사용할 때 최대 Temp 사용량임 . Used-Tmp와 다른 점은 마지막 수행시가 아니라 SQL을 여러 번 수행했을 경우에 항상 최대값만 보인다는 것임 . 보이는 값에 1024 를 곱해야 함.

 

6) 쿼리블럭 정보 : Plan 상의 Id 별로 쿼리블럭 및 Alias 정보를 출력한다.

Query block Name /  Object Alias ( identified by operation id ):
1- SEL$1
2- SEL$2 / from$_subquery$_001@SEL$1
3- SEL$2
4- SEL$2 / E@SEL$2
5- SEL$2 / E@SEL$2

 

7) Outline Data : 오라클이 내부적으로 사용한 힌트를 나타낸다.

Outline Data
-------------
 
  /*+
      BEGIN_OUTLINE_DATA
      IGNORE_OPTIM_EMBEDDED_HINTS
      OPTIMIZER_FEATURES_ENABLE('11.2.0.1')
      DB_VERSION('11.2.0.1')
      ALL_ROWS
      OUTLINE_LEAF(@"SEL$2")
      OUTLINE_LEAF(@"SEL$1")
      NO_ACCESS(@"SEL$1" "from$_subquery$_001"@"SEL$1")
      INDEX_RS_ASC(@"SEL$2" "E"@"SEL$2" ("EMPLOYEE"."DEPARTMENT_ID"))
      END_OUTLINE_DATA
*/

8) Predicate Information : Plan 상의 Id별로 인덱스,액세스,Filter , 조인정보 등을 나타낸다.

Predicate Information ( identified by operation id ) : 
1 - filter ( ROWNUM<=100 )
2 - filter ( ROWNUM<=100 )
5 - access(``E``.``DEPARTMENT_ID``=50 )

 

9) Column Projection Information : Plan 상의 Id 별로 Select 되는 컬럼의 정보를 나타낸다.
Column Projection Information ( identified by operation id ) :
1 - "from$_subquery$_100"."EMPLOYEE_ID"NUMBER,22, "from$-subquery$_001"."FIRST_NAME"VARCHAR2,20,"from$_subquery$_001"."LAST_NAME"VARCHAR2,25,
"from$_subquery$_001"."EMAIL"VARCHAR2,25, "from$_subquery$_001"."PHONE_NUMBER"VARCHAR2,20,"form$_subquery$_001"."HIRE_DATE"DATE,7
"from$_subquery$_001"."JOB_ID"VARCHAR2,10,"form$_subquery$_001"."SALARY"NUMBER,22,"from$_subquery$_001"."MANAGER_ID"NUMER,22,
2-"from$_SUBQUERY$_001"."employee_id"number,22

 

'advanced allstats last' 포맷은 출력되는 정보가 너무 많다.

>> DBMS_XPLAN.DISPAY_CURSOR 는 모든 정보를 출력

>> 튜닝 시 필요 없는 정보까지 출력

>> IT 핵심인 단순함을 추구하기가 힘듦 

 


*** 쿼리 변형이 없는 단순 쿼리 튜닝의 경우는 최대한 단순화 하라***

SELECT *

FROM

TABLE(DBMS_XPAN.DISPLAY_CURSOR(null,null,'allstats last -rows +predicate'));

 

'allstats last -rows +predicate'  => Row 수 (E-row) 가 생략되고 실행 통계와 predicate Information만 출력

 

***쿼리변형이 발생하거나 복잡한 쿼리 튜닝 시 쿼리블럭과 힌트정보를 추가로 출력하라***

SELECT *

FROM

TABLE(DBMS_XPAN.DISPLAY_CURSOR(null,null,'allstats last -rows +alias +outline +predicate'));

'allstats last -rows +alias +outline +predicate' => Query Block Name / Object Alias 정보  / Outline Data정보가 추가 출력

+alias  => 쿼리블럭을 추가

 +outline => 오라클 내부적으로 사용한 힌트 정보 출력

쿼리변형이 발생한 경우나 뷰(혹은 인라인뷰)등을 튜닝할 경우 아주 적합한 옵션

다른 특이한 경우 +projection 포맷 추가 => Column Projection Information 이 필요한 경우

 

***자신만의 적절한 포맷이 필요해***

출력되는 정보의 양이 너무 많으면 소화하기 힘들다

반대로 정보가 너무 적어도 어려워진다.

그러나 일반적으로 SQL 아무리 복잡하고 다양한 경우가 있더라도 위에 경우처럼 5~6 가지의 포맷 조합으로도 충분하다.

'OraclE' 카테고리의 다른 글

oracle hr schema 생성  (0) 2014.05.21
rman 백업 확인  (0) 2014.03.27
11g 스케줄러 자동작업 dbms_auto_task_admin  (0) 2014.02.12
Temporary Tablespace Group(10g)  (0) 2013.11.20
db link 사용시 lob타입 테이블 문제  (0) 2012.08.03

+ Recent posts