Professional Documents
Culture Documents
FULL Script Human Resources For Oracle Database
FULL Script Human Resources For Oracle Database
CREATE UNIQUE INDEX reg_id_pk ON regions (region_id); ALTER TABLE regions ADD (
CONSTRAINT reg_id_pk PRIMARY KEY (region_id) ); REM REM REM REM ****************
**************************************************** Create the COUNTRIES table
to hold country information for customers and company locations. OE.CUSTOMERS ta
ble and HR.LOCATIONS have a foreign key to this table. Creating COUNTRIES table
....
Prompt ******
CREATE TABLE countries ( country_id CHAR(2) CONSTRAINT country_id_nn NOT NULL ,
country_name VARCHAR2(40) , region_id NUMBER , CONSTRAINT country_c_id_pk PRIMAR
Y KEY (country_id) ) ORGANIZATION INDEX; ALTER TABLE countries ADD ( CONSTRAINT
countr_reg_fk FOREIGN KEY (region_id) REFERENCES regions(region_id) ); REM *****
*************************************************************** REM Create the L
OCATIONS table to hold address information for company departments. REM HR.DEPAR
TMENTS has a foreign key to this table. Prompt ****** Creating LOCATIONS table .
...
CREATE TABLE locations ( location_id NUMBER(4) , street_address VARCHAR2(40) , p
ostal_code VARCHAR2(12) , city VARCHAR2(30) CONSTRAINT loc_city_nn , state_provi
nce VARCHAR2(25) , country_id CHAR(2) ); CREATE UNIQUE INDEX loc_id_pk
NOT NULL
rem rem NOTES rem There is a circular foreign key reference between rem EMPLOYES
S and DEPARTMENTS. That's why we disable rem the FK constraints here rem rem CRE
ATED rem Nancy Greenberg, Nagavalli Pataballa - 06/01/00 rem rem MODIFIED (MM/DD
/YY) rem ahunold 03/07/01 - small data errors corrected rem - Modified region va
lues of countries table rem - Replaced ID sequence values for employees rem and
departments tables with numbers rem - Moved create sequence statements to hr_cre
rem - Removed dn values for employees and rem departments tables rem - Removed
currency columns values from rem countries table rem ngreenbe - Updated employee
178 for no department rem pnathan - Insert new rows to job_history table rem ah
unold 02/20/01 - NLS_LANGUAGE, replacing non American rem ahunold 01/09/01 - che
ckin ADE SET VERIFY OFF ALTER SESSION SET NLS_LANGUAGE=American; REM ***********
****************insert data into the REGIONS table Prompt ****** Populating REGI
ONS table ....
INSERT INTO regions VALUES (1 , 'Europe' ); INSERT INTO regions VALUES (2 , 'Ame
ricas' ); INSERT INTO regions VALUES (3 , 'Asia' ); INSERT INTO regions VALUES (
4 , 'Middle East and Africa' );
( 'BE' , 'Belgium' ,1 );
REM ***************************insert data into the LOCATIONS table Prompt *****
* Populating LOCATIONS table ....
INSERT INTO locations VALUES ( 1000 , '1297 Via Cola di Rie' , '00989' , 'Roma'
, NULL , 'IT' ); INSERT INTO locations VALUES ( 1100 , '93091 Calle della Testa'
, '10934' , 'Venice' , NULL , 'IT' ); INSERT INTO locations VALUES ( 1200 , '20
17 Shinjuku-ku' , '1689' , 'Tokyo' , 'Tokyo Prefecture' , 'JP' ); INSERT INTO lo
cations VALUES ( 1300 , '9450 Kamiya-cho' , '6823' , 'Hiroshima' , NULL , 'JP' )
; INSERT INTO locations VALUES ( 1400 , '2014 Jabberwocky Rd' , '26192'
, 'Oxford' , 'UK' ); INSERT INTO locations VALUES ( 2600 , '9702 Chester Road' ,
'09629850293' , 'Stretford' , 'Manchester' , 'UK' ); INSERT INTO locations VALU
ES ( 2700 , 'Schwanthalerstr. 7031' , '80925' , 'Munich' , 'Bavaria' , 'DE' ); I
NSERT INTO locations VALUES ( 2800 , 'Rua Frei Caneca 1360 ' , '01307-002' , 'Sa
o Paulo' , 'Sao Paulo' , 'BR' ); INSERT INTO locations VALUES ( 2900 , '20 Rue d
es Corps-Saints' , '1730' , 'Geneva' , 'Geneve' , 'CH' ); INSERT INTO locations
VALUES ( 3000 , 'Murtenstrasse 921' , '3095' , 'Bern' , 'BE' , 'CH' ); INSERT IN
TO locations VALUES
, 205 , 1700 ); INSERT INTO departments VALUES ( 120 , 'Treasury' , NULL , 1700
); INSERT INTO departments VALUES ( 130 , 'Corporate Tax' , NULL , 1700 ); INSER
T INTO departments VALUES ( 140 , 'Control And Credit' , NULL , 1700 ); INSERT I
NTO departments VALUES ( 150 , 'Shareholder Services' , NULL , 1700 ); INSERT IN
TO departments VALUES ( 160 , 'Benefits' , NULL , 1700 ); INSERT INTO department
s VALUES ( 170 , 'Manufacturing' , NULL , 1700 ); INSERT INTO departments VALUES
( 180 , 'Construction' , NULL
, 8500 ); INSERT INTO jobs VALUES ( 'ST_CLERK' , 'Stock Clerk' , 2000 , 5000 );
INSERT INTO jobs VALUES ( 'SH_CLERK' , 'Shipping Clerk' , 2500 , 5500 ); INSERT
INTO jobs VALUES ( 'IT_PROG' , 'Programmer' , 4000 , 10000 ); INSERT INTO jobs V
ALUES ( 'MK_MAN' , 'Marketing Manager' , 9000 , 15000 ); INSERT INTO jobs VALUES
( 'MK_REP' , 'Marketing Representative' , 4000 , 9000 ); INSERT INTO jobs VALUE
S ( 'HR_REP' , 'Human Resources Representative' , 4000 , 9000 ); INSERT INTO job
s VALUES ( 'PR_REP' , 'Public Relations Representative' , 4500 , 10500 );
, 5800 , NULL , 100 , 50 ); INSERT INTO employees VALUES ( 125 , 'Julia' , 'Naye
r' , 'JNAYER' , '650.124.1214' , TO_DATE('16-JUL-1997', 'dd-MON-yyyy') , 'ST_CLE
RK' , 3200 , NULL , 120 , 50 ); INSERT INTO employees VALUES ( 126 , 'Irene' , '
Mikkilineni' , 'IMIKKILI' , '650.124.1224' , TO_DATE('28-SEP-1998', 'dd-MON-yyyy
') , 'ST_CLERK' , 2700 , NULL , 120 , 50 ); INSERT INTO employees VALUES ( 127 ,
'James' , 'Landry' , 'JLANDRY' , '650.124.1334' , TO_DATE('14-JAN-1999', 'dd-MO
N-yyyy') , 'ST_CLERK' , 2400 , NULL , 120 , 50 ); INSERT INTO employees VALUES (
128
, 'Steven' , 'Markle' , 'SMARKLE' , '650.124.1434' , TO_DATE('08-MAR-2000', 'ddMON-yyyy') , 'ST_CLERK' , 2200 , NULL , 120 , 50 ); INSERT INTO employees VALUES
( 129 , 'Laura' , 'Bissot' , 'LBISSOT' , '650.124.5234' , TO_DATE('20-AUG-1997'
, 'dd-MON-yyyy') , 'ST_CLERK' , 3300 , NULL , 121 , 50 ); INSERT INTO employees
VALUES ( 130 , 'Mozhe' , 'Atkinson' , 'MATKINSO' , '650.124.6234' , TO_DATE('30OCT-1997', 'dd-MON-yyyy') , 'ST_CLERK' , 2800 , NULL , 121 , 50 ); INSERT INTO e
mployees VALUES ( 131 , 'James' , 'Marlow' , 'JAMRLOW' , '650.124.7234' , TO_DAT
E('16-FEB-1997', 'dd-MON-yyyy') , 'ST_CLERK' , 2500 , NULL
, 11000 , .30 , 149 , 80 ); INSERT INTO employees VALUES ( 175 , 'Alyssa' , 'Hut
ton' , 'AHUTTON' , '011.44.1644.429266' , TO_DATE('19-MAR-1997', 'dd-MON-yyyy')
, 'SA_REP' , 8800 , .25 , 149 , 80 ); INSERT INTO employees VALUES ( 176 , 'Jona
thon' , 'Taylor' , 'JTAYLOR' , '011.44.1644.429265' , TO_DATE('24-MAR-1998', 'dd
-MON-yyyy') , 'SA_REP' , 8600 , .20 , 149 , 80 ); INSERT INTO employees VALUES (
177 , 'Jack' , 'Livingston' , 'JLIVINGS' , '011.44.1644.429264' , TO_DATE('23-A
PR-1998', 'dd-MON-yyyy') , 'SA_REP' , 8400 , .20 , 149 , 80 ); INSERT INTO emplo
yees VALUES ( 178
, 2600 , NULL , 124 , 50 ); INSERT INTO employees VALUES ( 200 , 'Jennifer' , 'W
halen' , 'JWHALEN' , '515.123.4444' , TO_DATE('17-SEP-1987', 'dd-MON-yyyy') , 'A
D_ASST' , 4400 , NULL , 101 , 10 ); INSERT INTO employees VALUES ( 201 , 'Michae
l' , 'Hartstein' , 'MHARTSTE' , '515.123.5555' , TO_DATE('17-FEB-1996', 'dd-MONyyyy') , 'MK_MAN' , 13000 , NULL , 100 , 20 ); INSERT INTO employees VALUES ( 20
2 , 'Pat' , 'Fay' , 'PFAY' , '603.123.6666' , TO_DATE('17-AUG-1997', 'dd-MON-yyy
y') , 'MK_REP' , 6000 , NULL , 201 , 20 ); INSERT INTO employees VALUES ( 203
, 205 , 110 ); REM ********* insert data into the JOB_HISTORY table Prompt *****
* Populating JOB_HISTORY table ....
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 V
ALUES (101 , TO_DATE('21-SEP-1989', 'dd-MON-yyyy') , TO_DATE('27-OCT-1993', 'ddMON-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-yy
yy') , TO_DATE('19-DEC-1999', 'dd-MON-yyyy') , 'MK_REP' , 20); INSERT INTO job_h
istory VALUES (114 , TO_DATE('24-MAR-1998', 'dd-MON-yyyy') , TO_DATE('31-DEC-199
9', 'dd-MON-yyyy') , 'ST_CLERK' , 50 ); INSERT INTO job_history VALUES (122 , TO
_DATE('01-JAN-1999', 'dd-MON-yyyy') , TO_DATE('31-DEC-1999', 'dd-MON-yyyy') , 'S
T_CLERK'
Rem Rem Rem Rem Rem Rem Rem Rem Rem Rem Rem Rem SET SET SET SET SET SET SET
hr_idx.sql - Create indexes for HR schema DESCRIPTION
NOTES
CREATED by Nancy Greenberg - 06/01/00 MODIFIED (MM/DD/YY) ahunold 02/20/01 - New
header vpatabal 03/02/01 - Removed DROP INDEX statements FEEDBACK 1 NUMWIDTH 10
LINESIZE 80 TRIMSPOOL ON TAB OFF PAGESIZE 100 ECHO OFF
CREATE INDEX emp_department_ix ON employees (department_id); CREATE INDEX emp_jo
b_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 d
ept_location_ix ON departments (location_id); CREATE INDEX jhist_job_ix ON job_h
istory (job_id); CREATE INDEX jhist_employee_ix ON job_history (employee_id); CR
EATE 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 (st
ate_province);
Rem hr_comnt.sql Rem Rem Copyright (c) Oracle Corporation 2001. All Rights Reser
ved. Rem Rem NAME Rem hr_comnt.sql - Create comments for HR schema Rem Rem DESCR
IPTION Rem Rem Rem CREATED by Nancy Greenberg, Nagavalli Pataballa - 06/01/00 Re
m MODIFIED (MM/DD/YY) Rem ahunold 02/20/01 - New header Rem vpatabal 03/02/01 Added comments for Regions table Rem - Removed references to currency symbol Rem
and currency name columns of countries Rem - Removed comments to DN column of R
em employees and departments. Rem - Removed references to sequences SET SET SET
SET SET SET SET FEEDBACK 1 NUMWIDTH 10 LINESIZE 80 TRIMSPOOL ON TAB OFF PAGESIZE
100 ECHO OFF
COMMENT ON TABLE regions IS 'Regions table that contains region numbers and name
s. Contains 4 rows; references with the Countries table.' ; COMMENT ON COLUMN re
gions.region_id IS 'Primary key of regions table.' ; COMMENT ON COLUMN regions.r
egion_name IS 'Names of regions. Locations are in the countries of these regions
.' ; COMMENT ON TABLE locations IS 'Locations table that contains specific addre
ss of a specific office, warehouse, and/or production site of a company. Does no
t store addresses / locations of customers. Contains 23 rows; references with th
e departments and countries tables. '; COMMENT ON COLUMN locations.location_id I
S 'Primary key of locations table'; COMMENT ON COLUMN locations.street_address I
S 'Street address of an office, warehouse, or production site of a company.
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 fo
r a job title.'; COMMENT ON COLUMN jobs.max_salary IS 'Maximum salary for a job
title'; REM ********************************************* COMMENT ON TABLE emplo
yees IS 'employees table. Contains 107 rows. References with departments, jobs,
job_history tables. Contains a self reference.'; COMMENT ON COLUMN employees.emp
loyee_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 emp
loyees.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 employee
s.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 CO
LUMN employees.manager_id IS 'Manager id of the employee; has same domain as man
ager_id in departments table. Foreign key to employee_id column of employees tab
le. (useful for reflexive joins and CONNECT BY query)';
FROM employees); DELETE FROM departments WHERE department_id NOT IN (SELECT DIST
INCT department_id FROM employees WHERE department_id IS NOT NULL); UPDATE depar
tments SET manager_id = 124 WHERE department_id = 50; UPDATE departments SET man
ager_id = 149 WHERE department_id = 80; DELETE FROM locations WHERE location_id
IN (2700, 2400); UPDATE locations SET street_address = '460 Bloor St. W.', posta
l_code = 'ON M5S 1X8' WHERE location_id = 1800; ALTER TABLE departments ENABLE C
ONSTRAINT DEPT_MGR_FK; CREATE TABLE (grade_level lowest_sal highest_sal job_grad
es VARCHAR2(3), NUMBER, NUMBER);
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 jo
b_grades VALUES('D', 10000, 14999); INSERT INTO job_grades VALUES('E', 15000, 24
999); INSERT INTO job_grades VALUES('F', 25000, 40000);