Adm AdminDatabaseAllTopic

126
Copyright © 2004, Oracle. All rights reserved. Controlling User Access

description

PLQSL

Transcript of Adm AdminDatabaseAllTopic

  • Copyright 2004, Oracle. All rights reserved.

    Controlling User Access

  • 1-2 Copyright 2004, Oracle. All rights reserved.

    Objectives

    After completing this lesson, you should be able to do the following: Differentiate system privileges from object

    privileges Grant privileges on tables View privileges in the data dictionary Grant roles Distinguish between privileges and roles

  • 1-3 Copyright 2004, Oracle. All rights reserved.

    Controlling User Access

    Databaseadministrator

    Users

    Username and passwordPrivileges

  • 1-4 Copyright 2004, Oracle. All rights reserved.

    Privileges

    Database security: System security Data security

    System privileges: Gaining access to the database Object privileges: Manipulating the content of the

    database objects Schemas: Collection of objects such as tables,

    views, and sequences

  • 1-5 Copyright 2004, Oracle. All rights reserved.

    System Privileges

    More than 100 privileges are available. The database administrator has high-level system

    privileges for tasks such as: Creating new users Removing users Removing tables Backing up tables

  • 1-6 Copyright 2004, Oracle. All rights reserved.

    Creating Users

    The DBA creates users with the CREATE USERstatement.

    CREATE USER HRIDENTIFIED BY HR;User created.

    CREATE USER userIDENTIFIED BY password;

  • 1-7 Copyright 2004, Oracle. All rights reserved.

    User System Privileges

    After a user is created, the DBA can grant specific system privileges to that user.

    An application developer, for example, may have the following system privileges: CREATE SESSION CREATE TABLE CREATE SEQUENCE CREATE VIEW CREATE PROCEDURE

    GRANT privilege [, privilege...]TO user [, user| role, PUBLIC...];

  • 1-8 Copyright 2004, Oracle. All rights reserved.

    Granting System Privileges

    The DBA can grant specific system privileges to a user.GRANT create session, create table,

    create sequence, create viewTO hr;Grant succeeded.

  • 1-9 Copyright 2004, Oracle. All rights reserved.

    What Is a Role?

    Allocating privilegeswithout a role

    Allocating privilegeswith a role

    Privileges

    Users

    Manager

  • 1-10 Copyright 2004, Oracle. All rights reserved.

    Creating and Granting Privileges to a Role

    Create a role

    Grant privileges to a role

    Grant a role to users

    CREATE ROLE manager;Role created.

    GRANT create table, create view TO manager; Grant succeeded.

    GRANT manager TO DE HAAN, KOCHHAR; Grant succeeded.

  • 1-11 Copyright 2004, Oracle. All rights reserved.

    Predefined Roles

    CONNECT CREATE SESSION

    RESOURCE CREATE CLUSTER, CREATE INDEXTYPE,CREATE OPERATOR, CREATE PROCEDURE,CREATE SEQUENCE, CREATE TABLE, CREATE TRIGGER, CREATE TYPE

    SCHEDULER_ ADMIN

    CREATE ANY JOB, CREATE EXTERNAL JOB,CREATE JOB, EXECUTE ANY CLASS, EXECUTE ANY PROGRAM, MANAGE SCHEDULER

    DBA Most system privileges, several other roles. Do not grant to nonadministrators.

    SELECT_CATALOG_ROLE

    No system privileges, but HS_ADMIN_ROLE and over 1,700 object privileges on the data dictionary

  • 1-12 Copyright 2004, Oracle. All rights reserved.

    Changing Your Password

    The DBA creates your user account and initializes your password.

    You can change your password by using the ALTER USER statement.

    ALTER USER HR IDENTIFIED BY employ;User altered.

  • 1-13 Copyright 2004, Oracle. All rights reserved.

    Object Privileges

    Object Privilege Table View Sequence Procedure

    ALTER

    DELETE

    EXECUTE

    INDEX

    INSERT

    REFERENCES

    SELECT UPDATE

  • 1-14 Copyright 2004, Oracle. All rights reserved.

    Object Privileges

    Object privileges vary from object to object. An owner has all the privileges on the object. An owner can give specific privileges on that

    owners object.GRANT object_priv [(columns)]ON objectTO {user|role|PUBLIC}[WITH GRANT OPTION];

  • 1-15 Copyright 2004, Oracle. All rights reserved.

    Granting Object Privileges

    Grant query privileges on the EMPLOYEES table.

    Grant privileges to update specific columns to users and roles.

    GRANT selectON employeesTO sue, rich;Grant succeeded.

    GRANT update (department_name, location_id)ON departmentsTO scott, manager;Grant succeeded.

  • 1-16 Copyright 2004, Oracle. All rights reserved.

    Passing On Your Privileges

    Give a user authority to pass along privileges.

    Allow all users on the system to query data from Alices DEPARTMENTS table.

    GRANT select, insertON departmentsTO scottWITH GRANT OPTION;Grant succeeded.

    GRANT selectON alice.departmentsTO PUBLIC;Grant succeeded.

  • 1-17 Copyright 2004, Oracle. All rights reserved.

    Confirming Privileges Granted

    Data Dictionary View DescriptionROLE_SYS_PRIVS System privileges granted to rolesROLE_TAB_PRIVS Table privileges granted to rolesUSER_ROLE_PRIVS Roles accessible by the userUSER_TAB_PRIVS_MADE Object privileges granted on the users

    objectsUSER_TAB_PRIVS_RECD Object privileges granted to the userUSER_COL_PRIVS_MADE Object privileges granted on the

    columns of the users objectsUSER_COL_PRIVS_RECD Object privileges granted to the user on

    specific columnsUSER_SYS_PRIVS System privileges granted to the user

  • 1-18 Copyright 2004, Oracle. All rights reserved.

    Revoking Object Privileges

    You use the REVOKE statement to revoke privileges granted to other users.

    Privileges granted to others through the WITH GRANT OPTION clause are also revoked.

    REVOKE {privilege [, privilege...]|ALL}ON objectFROM {user[, user...]|role|PUBLIC}[CASCADE CONSTRAINTS];

  • 1-19 Copyright 2004, Oracle. All rights reserved.

    Revoking Object Privileges

    As user Alice, revoke the SELECT and INSERTprivileges given to user Scott on the DEPARTMENTStable.REVOKE select, insertON departmentsFROM scott;Revoke succeeded.

  • 1-20 Copyright 2004, Oracle. All rights reserved.

    Summary

    In this lesson, you should have learned about statements that control access to the database and database objects.

    Statement ActionCREATE USER Creates a user (usually performed by a DBA)GRANT Gives other users privileges to access the

    objectsCREATE ROLE Creates a collection of privileges (usually

    performed by a DBA)ALTER USER Changes a users passwordREVOKE Removes privileges on an object from users

  • 1-21 Copyright 2004, Oracle. All rights reserved.

    Practice 1: Overview

    This practice covers the following topics: Granting other users privileges to your table Modifying another users table through the

    privileges granted to you Creating a synonym Querying the data dictionary views related to

    privileges

  • Copyright 2004, Oracle. All rights reserved.

    Using DDL Statementsto Create and Manage Tables

  • 1-23 Copyright 2004, Oracle. All rights reserved.

    Objectives

    After completing this lesson, you should be able to do the following: Categorize the main database objects Review the table structure List the data types that are available for columns Create a simple table Understand how constraints are created at the

    time of table creation Describe how schema objects work

  • 1-24 Copyright 2004, Oracle. All rights reserved.

    Database Objects

    Object DescriptionTable Basic unit of storage; composed of rows View Logically represents subsets of data from

    one or more tables Sequence Generates numeric valuesIndex Improves the performance of some

    queriesSynonym Gives alternative names to objects

  • 1-25 Copyright 2004, Oracle. All rights reserved.

    Naming Rules

    Table names and column names: Must begin with a letter Must be 130 characters long Must contain only AZ, az, 09, _, $, and # Must not duplicate the name of another object

    owned by the same user Must not be an Oracle server reserved word

  • 1-26 Copyright 2004, Oracle. All rights reserved.

    You must have: CREATE TABLE privilege A storage area

    You specify: Table name Column name, column data type, and column size

    CREATE TABLE Statement

    CREATE TABLE [schema.]table(column datatype [DEFAULT expr][, ...]);

  • 1-27 Copyright 2004, Oracle. All rights reserved.

    Referencing Another Users Tables

    Tables belonging to other users are not in the users schema.

    You should use the owners name as a prefix to those tables.

    USERBUSERASELECT * FROM userB.employees;

    SELECT * FROM userA.employees;

  • 1-28 Copyright 2004, Oracle. All rights reserved.

    Specify a default value for a column during an insert.

    Literal values, expressions, or SQL functions are legal values.

    Another columns name or a pseudocolumn are illegal values.

    The default data type must match the column data type.

    DEFAULT Option

    ... hire_date DATE DEFAULT SYSDATE, ...

    CREATE TABLE hire_dates(id NUMBER(8),hire_date DATE DEFAULT SYSDATE);

    Table created.

  • 1-29 Copyright 2004, Oracle. All rights reserved.

    Creating Tables

    Create the table.

    Confirm table creation.DESCRIBE dept

    CREATE TABLE dept(deptno NUMBER(2),dname VARCHAR2(14),loc VARCHAR2(13),create_date DATE DEFAULT SYSDATE);

    Table created.

  • 1-30 Copyright 2004, Oracle. All rights reserved.

    Data Types

    Data Type DescriptionVARCHAR2(size) Variable-length character dataCHAR(size) Fixed-length character dataNUMBER(p,s) Variable-length numeric dataDATE Date and time valuesLONG Variable-length character data (up to 2 GB)CLOB Character data (up to 4 GB)RAW and LONG RAW

    Raw binary data

    BLOB Binary data (up to 4 GB)BFILE Binary data stored in an external file (up to 4 GB)ROWID A base-64 number system representing the unique

    address of a row in its table

  • 1-31 Copyright 2004, Oracle. All rights reserved.

    Datetime Data Types

    You can use several datetime data types:Data Type DescriptionTIMESTAMP Date with fractional secondsINTERVAL YEAR TO MONTH

    Stored as an interval of yearsand months

    INTERVAL DAY TO SECOND

    Stored as an interval of days, hours, minutes, and seconds

  • 1-32 Copyright 2004, Oracle. All rights reserved.

    Datetime Data Types

    The TIMESTAMP data type is an extension of the DATE data type.

    It stores the year, month, and day of the DATE data type plus hour, minute, and second values as well as the fractional second value.

    You can optionally specify the time zone.TIMESTAMP[(fractional_seconds_precision)]

    TIMESTAMP[(fractional_seconds_precision)]WITH TIME ZONE

    TIMESTAMP[(fractional_seconds_precision)]WITH LOCAL TIME ZONE

  • 1-33 Copyright 2004, Oracle. All rights reserved.

    Datetime Data Types

    The INTERVAL YEAR TO MONTH data type stores a period of time using the YEAR and MONTH datetime fields:

    The INTERVAL DAY TO SECOND data type stores a period of time in terms of days, hours, minutes, and seconds:

    INTERVAL YEAR [(year_precision)] TO MONTH

    INTERVAL DAY [(day_precision)] TO SECOND [(fractional_seconds_precision)]

  • 1-34 Copyright 2004, Oracle. All rights reserved.

    INTERVAL DAY TO SECOND Data Type

    INTERVAL DAY TO SECOND stores a period of time in terms of days, hours, minutes, and seconds.INTERVAL '4 5:12:10.222' DAY TO SECOND(3)Indicates 4 days, 5 hours, 12 minutes, 10 seconds, and 222 thousandths of a second.

    INTERVAL '4 5:12' DAY TO MINUTEIndicates 4 days, 5 hours and 12 minutes.

    INTERVAL '400 5' DAY(3) TO HOURIndicates 400 days 5 hours.

    INTERVAL '11:12:10.2222222' HOUR TO SECOND(7)indicates 11 hours, 12 minutes, and 10.2222222 seconds.

  • 1-35 Copyright 2004, Oracle. All rights reserved.

    Including Constraints

    Constraints enforce rules at the table level. Constraints prevent the deletion of a table if there

    are dependencies. The following constraint types are valid:

    NOT NULL UNIQUE PRIMARY KEY FOREIGN KEY CHECK

  • 1-36 Copyright 2004, Oracle. All rights reserved.

    Constraint Guidelines

    You can name a constraint, or the Oracle server generates a name by using the SYS_Cn format.

    Create a constraint at either of the following times: At the same time as the table is created After the table has been created

    Define a constraint at the column or table level. View a constraint in the data dictionary.

  • 1-37 Copyright 2004, Oracle. All rights reserved.

    Defining Constraints

    Syntax:

    Column-level constraint:

    Table-level constraint:

    CREATE TABLE [schema.]table(column datatype [DEFAULT expr][column_constraint],...[table_constraint][,...]);

    column,...[CONSTRAINT constraint_name] constraint_type(column, ...),

    column [CONSTRAINT constraint_name] constraint_type,

  • 1-38 Copyright 2004, Oracle. All rights reserved.

    Defining Constraints

    Column-level constraint:

    Table-level constraint:

    CREATE TABLE employees(employee_id NUMBER(6)CONSTRAINT emp_emp_id_pk PRIMARY KEY,

    first_name VARCHAR2(20),...);

    CREATE TABLE employees(employee_id NUMBER(6),first_name VARCHAR2(20),...job_id VARCHAR2(10) NOT NULL,CONSTRAINT emp_emp_id_pk PRIMARY KEY (EMPLOYEE_ID));

    1

    2

  • 1-39 Copyright 2004, Oracle. All rights reserved.

    NOT NULL Constraint

    Ensures that null values are not permitted for the column:

    NOT NULL constraint(No row can containa null value forthis column.)

    Absence of NOT NULLconstraint (Any row can contain a null value for this column.)

    NOT NULLconstraint

  • 1-40 Copyright 2004, Oracle. All rights reserved.

    UNIQUE Constraint

    EMPLOYEES UNIQUE constraint

    INSERT INTO

    Not allowed: already existsAllowed

  • 1-41 Copyright 2004, Oracle. All rights reserved.

    UNIQUE Constraint

    Defined at either the table level or the column level:

    CREATE TABLE employees(employee_id NUMBER(6),last_name VARCHAR2(25) NOT NULL,email VARCHAR2(25),salary NUMBER(8,2),commission_pct NUMBER(2,2),hire_date DATE NOT NULL,

    ... CONSTRAINT emp_email_uk UNIQUE(email));

  • 1-42 Copyright 2004, Oracle. All rights reserved.

    PRIMARY KEY Constraint

    DEPARTMENTSPRIMARY KEY

    INSERT INTONot allowed(null value)

    Not allowed (50 already exists)

  • 1-43 Copyright 2004, Oracle. All rights reserved.

    FOREIGN KEY ConstraintDEPARTMENTS

    EMPLOYEESFOREIGNKEY

    INSERT INTO Not allowed(9 does not exist)

    Allowed

    PRIMARYKEY

  • 1-44 Copyright 2004, Oracle. All rights reserved.

    FOREIGN KEY Constraint

    Defined at either the table level or the column level:

    CREATE TABLE employees(employee_id NUMBER(6),last_name VARCHAR2(25) NOT NULL,email VARCHAR2(25),salary NUMBER(8,2),commission_pct NUMBER(2,2),hire_date DATE NOT NULL,

    ...department_id NUMBER(4),CONSTRAINT emp_dept_fk FOREIGN KEY (department_id)

    REFERENCES departments(department_id),CONSTRAINT emp_email_uk UNIQUE(email));

  • 1-45 Copyright 2004, Oracle. All rights reserved.

    FOREIGN KEY Constraint:Keywords

    FOREIGN KEY: Defines the column in the child table at the table-constraint level

    REFERENCES: Identifies the table and column in the parent table

    ON DELETE CASCADE: Deletes the dependent rows in the child table when a row in the parent table is deleted

    ON DELETE SET NULL: Converts dependent foreign key values to null

  • 1-46 Copyright 2004, Oracle. All rights reserved.

    CHECK Constraint

    Defines a condition that each row must satisfy The following expressions are not allowed:

    References to CURRVAL, NEXTVAL, LEVEL, and ROWNUM pseudocolumns

    Calls to SYSDATE, UID, USER, and USERENVfunctions

    Queries that refer to other values in other rows..., salary NUMBER(2)

    CONSTRAINT emp_salary_min CHECK (salary > 0),...

  • 1-47 Copyright 2004, Oracle. All rights reserved.

    CREATE TABLE: ExampleCREATE TABLE employees

    ( employee_id NUMBER(6)CONSTRAINT emp_employee_id PRIMARY KEY

    , first_name VARCHAR2(20), last_name VARCHAR2(25)

    CONSTRAINT emp_last_name_nn NOT NULL, email VARCHAR2(25)

    CONSTRAINT emp_email_nn NOT NULLCONSTRAINT 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_nn NOT NULL, salary NUMBER(8,2)

    CONSTRAINT emp_salary_ck CHECK (salary>0), commission_pct NUMBER(2,2), manager_id NUMBER(6), department_id NUMBER(4)

    CONSTRAINT emp_dept_fk REFERENCESdepartments (department_id));

  • 1-48 Copyright 2004, Oracle. All rights reserved.

    UPDATE employees*

    ERROR at line 1:ORA-02291: integrity constraint (HR.EMP_DEPT_FK) violated - parent key not found

    UPDATE employeesSET department_id = 55WHERE department_id = 110;

    Violating Constraints

  • 1-49 Copyright 2004, Oracle. All rights reserved.

    Violating Constraints

    You cannot delete a row that contains a primary key that is used as a foreign key in another table.DELETE FROM departmentsWHERE department_id = 60;

    DELETE FROM departments*

    ERROR at line 1:ORA-02292: integrity constraint (HR.EMP_DEPT_FK) violated - child record found

  • 1-50 Copyright 2004, Oracle. All rights reserved.

    Creating a Tableby Using a Subquery

    Create a table and insert rows by combining the CREATE TABLE statement and the AS subqueryoption.

    Match the number of specified columns to the number of subquery columns.

    Define columns with column names anddefault values.

    CREATE TABLE table[(column, column...)]

    AS subquery;

  • 1-51 Copyright 2004, Oracle. All rights reserved.

    CREATE TABLE dept80AS SELECT employee_id, last_name,

    salary*12 ANNSAL, hire_date

    FROM employeesWHERE department_id = 80;

    Table created.

    Creating a Tableby Using a Subquery

    DESCRIBE dept80

  • 1-52 Copyright 2004, Oracle. All rights reserved.

    ALTER TABLE Statement

    Use the ALTER TABLE statement to: Add a new column Modify an existing column Define a default value for the new column Drop a column

  • 1-53 Copyright 2004, Oracle. All rights reserved.

    Dropping a Table

    All data and structure in the table are deleted. Any pending transactions are committed. All indexes are dropped. All constraints are dropped. You cannot roll back the DROP TABLE statement.DROP TABLE dept80;Table dropped.

  • 1-54 Copyright 2004, Oracle. All rights reserved.

    Summary

    In this lesson, you should have learned how to use the CREATE TABLE statement to create a table and include constraints. Categorize the main database objects Review the table structure List the data types that are available for columns Create a simple table Understand how constraints are created at the

    time of table creation Describe how schema objects work

  • 1-55 Copyright 2004, Oracle. All rights reserved.

    Practice 9: Overview

    This practice covers the following topics: Creating new tables Creating a new table by using the CREATE TABLE

    AS syntax Verifying that tables exist Dropping tables

  • Copyright 2004, Oracle. All rights reserved.

    Manage Schema Objects

  • 1-57 Copyright 2004, Oracle. All rights reserved.

    Objectives

    After completing this lesson, you should be able to do the following: Add constraints Create indexes Create and manage indexes Creating function-based indexes Drop columns and set column UNUSED Perform FLASHBACK operations Create and use external tables

  • 1-58 Copyright 2004, Oracle. All rights reserved.

    The ALTER TABLE Statement

    Use the ALTER TABLE statement to: Add a new column Modify an existing column Define a default value for the new column Drop a column

  • 1-59 Copyright 2004, Oracle. All rights reserved.

    The ALTER TABLE Statement

    Use the ALTER TABLE statement to add, modify, or drop columns.ALTER TABLE tableADD (column datatype [DEFAULT expr]

    [, column datatype]...);

    ALTER TABLE tableMODIFY (column datatype [DEFAULT expr]

    [, column datatype]...);

    ALTER TABLE tableDROP (column);

  • 1-60 Copyright 2004, Oracle. All rights reserved.

    Adding a Column

    You use the ADD clause to add columns.

    The new column becomes the last column.

    ALTER TABLE dept80ADD (job_id VARCHAR2(9));Table altered.

  • 1-61 Copyright 2004, Oracle. All rights reserved.

    Modifying a Column

    You can change a columns data type, size, and default value.

    A change to the default value affects only subsequent insertions to the table.

    ALTER TABLE dept80MODIFY (last_name VARCHAR2(30));Table altered.

  • 1-62 Copyright 2004, Oracle. All rights reserved.

    Dropping a Column

    Use the DROP COLUMN clause to drop columns you no longer need from the table.ALTER TABLE dept80DROP COLUMN job_id; Table altered.

  • 1-63 Copyright 2004, Oracle. All rights reserved.

    ALTER TABLE SET UNUSED();

    ALTER TABLE SET UNUSED COLUMN ;

    The SET UNUSED Option

    You use the SET UNUSED option to mark one or more columns as unused.

    You use the DROP UNUSED COLUMNS option to remove the columns that are marked as unused.

    OR

    ALTER TABLE DROP UNUSED COLUMNS;

  • 1-64 Copyright 2004, Oracle. All rights reserved.

    Adding a Constraint Syntax

    Use the ALTER TABLE statement to: Add or drop a constraint, but not modify its

    structure Enable or disable constraints Add a NOT NULL constraint by using the MODIFY

    clauseALTER TABLE ADD [CONSTRAINT ] type ();

  • 1-65 Copyright 2004, Oracle. All rights reserved.

    ALTER TABLE emp2modify employee_id Primary Key;Table altered.

    Adding a Constraint

    Add a FOREIGN KEY constraint to the EMP2 table indicating that a manager must already exist as a valid employee in the EMP2 table.

    ALTER TABLE emp2ADD CONSTRAINT emp_mgr_fk FOREIGN KEY(manager_id) REFERENCES emp2(employee_id);

    Table altered.

  • 1-66 Copyright 2004, Oracle. All rights reserved.

    ON DELETE CASCADE

    Delete child rows when a parent key is deleted.ALTER TABLE Emp2 ADD CONSTRAINT emp_dt_fk FOREIGN KEY (Department_id) REFERENCES departments ON DELETE CASCADE); Table altered.

  • 1-67 Copyright 2004, Oracle. All rights reserved.

    Deferring Constraints

    Constraints can have the following attributes: DEFERRABLE or NOT DEFERRABLE INITIALLY DEFERRED or INITIALLY IMMEDIATEALTER TABLE dept2ADD CONSTRAINT dept2_id_pk PRIMARY KEY (department_id)DEFERRABLE INITIALLY DEFERRED

    ALTER SESSION SET CONSTRAINTS= IMMEDIATE

    SET CONSTRAINTS dept2_id_pk IMMEDIATE

    Deferring constraint on creation

    Changing all constraints for a session

    Changing a specific constraint attribute

  • 1-68 Copyright 2004, Oracle. All rights reserved.

    Dropping a Constraint

    Remove the manager constraint from the EMP2table.

    Remove the PRIMARY KEY constraint on the DEPT2 table and drop the associated FOREIGN KEY constraint on the EMP2.DEPARTMENT_IDcolumn.

    ALTER TABLE emp2DROP CONSTRAINT emp_mgr_fk;Table altered.

    ALTER TABLE dept2DROP PRIMARY KEY CASCADE;Table altered.

  • 1-69 Copyright 2004, Oracle. All rights reserved.

    Disabling Constraints

    Execute the DISABLE clause of the ALTER TABLEstatement to deactivate an integrity constraint.

    Apply the CASCADE option to disable dependent integrity constraints.

    ALTER TABLE emp2DISABLE CONSTRAINT emp_dt_fk;Table altered.

  • 1-70 Copyright 2004, Oracle. All rights reserved.

    Enabling Constraints

    Activate an integrity constraint currently disabled in the table definition by using the ENABLE clause.

    A UNIQUE index is automatically created if you enable a UNIQUE key or PRIMARY KEY constraint.

    ALTER TABLE emp2ENABLE CONSTRAINT emp_dt_fk;Table altered.

  • 1-71 Copyright 2004, Oracle. All rights reserved.

    Cascading Constraints

    The CASCADE CONSTRAINTS clause is used along with the DROP COLUMN clause.

    The CASCADE CONSTRAINTS clause drops all referential integrity constraints that refer to the primary and unique keys defined on the dropped columns.

    The CASCADE CONSTRAINTS clause also drops all multicolumn constraints defined on the dropped columns.

  • 1-72 Copyright 2004, Oracle. All rights reserved.

    Cascading Constraints

    Example:ALTER TABLE emp2 DROP COLUMN employee_id CASCADE CONSTRAINTS;Table altered.

    ALTER TABLE test1DROP (pk, fk, col1) CASCADE CONSTRAINTS;Table altered.

  • 1-73 Copyright 2004, Oracle. All rights reserved.

    Indexes

    An index: Is a schema object Is used by the Oracle server to speed up the

    retrieval of rows by using a pointer Can reduce disk I/O by using a rapid path access

    method to locate data quickly Is independent of the table that it indexes Is used and maintained automatically by the

    Oracle server

  • 1-74 Copyright 2004, Oracle. All rights reserved.

    How Are Indexes Created?

    Automatically: A unique index is created automatically when you define a PRIMARY KEY or UNIQUE constraint in a table definition.

    Manually: Users can create nonunique indexes on columns to speed up access to the rows.

  • 1-75 Copyright 2004, Oracle. All rights reserved.

    Overview of Indexes

    Indexes are created: Automatically

    PRIMARY KEY creation UNIQUE KEY creation

    Manually CREATE INDEX statement CREATE TABLE statement

  • 1-76 Copyright 2004, Oracle. All rights reserved.

    Creating an Index

    Create an index on one or more columns:

    Improve the speed of query access to the LAST_NAME column in the EMPLOYEES table:

    CREATE INDEX emp_last_name_idxON employees(last_name);Index created.

    CREATE INDEX indexON table (column[, column]...);

  • 1-77 Copyright 2004, Oracle. All rights reserved.

    Index Creation Guidelines

    Create an index when:!!!! A column contains a wide range of values!!!! A column contains a large number of null values!!!! One or more columns are frequently used together in a WHERE

    clause or a join condition!!!! The table is large and most queries are expected to retrieve less

    than 2% to 4% of the rows in the tableDo not create an index when:"""" The columns are not often used as a condition in the query

    """" The table is small or most queries are expected to retrieve more than 2% to 4% of the rows in the table

    """" The table is updated frequently

    """" The indexed columns are referenced as part of an expression

  • 1-78 Copyright 2004, Oracle. All rights reserved.

    CREATE INDEX with CREATE TABLEStatement

    CREATE TABLE NEW_EMP(employee_id NUMBER(6)

    PRIMARY KEY USING INDEX(CREATE INDEX emp_id_idx ONNEW_EMP(employee_id)),

    first_name VARCHAR2(20),last_name VARCHAR2(25));Table created.

    SELECT INDEX_NAME, TABLE_NAME FROM USER_INDEXESWHERE TABLE_NAME = 'NEW_EMP';

  • 1-79 Copyright 2004, Oracle. All rights reserved.

    CREATE INDEX upper_dept_name_idxON dept2(UPPER(department_name));

    Index created.

    SELECT *FROM dept2WHERE UPPER(department_name) = 'SALES';

    Function-Based Indexes

    A function-based index is based on expressions. The index expression is built from table columns,

    constants, SQL functions, and user-defined functions.

  • 1-80 Copyright 2004, Oracle. All rights reserved.

    Removing an Index

    Remove an index from the data dictionary by using the DROP INDEX command:

    Remove the UPPER_LAST_NAME_IDX index from the data dictionary:

    To drop an index, you must be the owner of the index or have the DROP ANY INDEX privilege.

    DROP INDEX emp_last_name_idx;Index dropped.

    DROP INDEX index;

  • 1-81 Copyright 2004, Oracle. All rights reserved.

    DROP TABLE PURGE

    DROP TABLE dept80 PURGE;

  • 1-82 Copyright 2004, Oracle. All rights reserved.

    The FLASHBACK TABLE Statement

    Repair tool for accidental table modifications Restores a table to an earlier point in time Benefits: Ease of use, availability, fast execution Performed in place

    Syntax:

    FLASHBACK TABLE[schema.]table[,[ schema.]table ]...TO { TIMESTAMP | SCN } expr[ { ENABLE | DISABLE } TRIGGERS ];

  • 1-83 Copyright 2004, Oracle. All rights reserved.

    The FLASHBACK TABLE Statement

    DROP TABLE emp2;Table dropped

    FLASHBACK TABLE emp2 TO BEFORE DROP;Flashback complete

    SELECT original_name, operation, droptime, FROM recyclebin;

  • 1-84 Copyright 2004, Oracle. All rights reserved.

    External Tables

  • 1-85 Copyright 2004, Oracle. All rights reserved.

    Creating a Directory for the External Table

    Create a DIRECTORY object that corresponds to the directory on the file system where the external data source resides.

    CREATE OR REPLACE DIRECTORY emp_dir AS '//emp_dir';

    GRANT READ ON DIRECTORY emp_dir TO hr;

  • 1-86 Copyright 2004, Oracle. All rights reserved.

    Creating an External Table

    CREATE TABLE ( , )

    ORGANIZATION EXTERNAL (TYPE DEFAULT DIRECTORY ACCESS PARAMETERS ( ) ) LOCATION ('') )

    REJECT LIMIT [0 | | UNLIMITED];

  • 1-87 Copyright 2004, Oracle. All rights reserved.

    Creating an External Table Using ORACLE_LOADER

    CREATE TABLE oldemp ( fname char(25), lname CHAR(25))ORGANIZATION EXTERNAL(TYPE ORACLE_LOADERDEFAULT DIRECTORY emp_dirACCESS PARAMETERS(RECORDS DELIMITED BY NEWLINENOBADFILE NOLOGFILE FIELDS TERMINATED BY ',)

    LOCATION ('emp.dat'))PARALLEL 5REJECT LIMIT 200;

    Table created.

  • 1-88 Copyright 2004, Oracle. All rights reserved.

    Querying External Tables

    SELECT * FROM oldemp

    emp.datOLDEMP

  • 1-89 Copyright 2004, Oracle. All rights reserved.

    Summary

    In this lesson, you should have learned how to: Add constraints Create indexes Create a primary key constraint using an index Create indexes using the CREATE TABLE

    statement Creating function-based indexes Drop columns and set column UNUSED Perform FLASHBACK operations Create and use external tables

  • 1-90 Copyright 2004, Oracle. All rights reserved.

    Practice 2: Overview

    This practice covers the following topics: Altering tables Adding columns Dropping columns Creating indexes Creating external tables

  • Copyright 2004, Oracle. All rights reserved.

    Creating Other Schema Objects

  • 1-92 Copyright 2004, Oracle. All rights reserved.

    Objectives

    After completing this lesson, you should be able to do the following: Create simple and complex views Retrieve data from views Create, maintain, and use sequences Create and maintain indexes Create private and public synonyms

  • 1-93 Copyright 2004, Oracle. All rights reserved.

    Database Objects

    Object Description

    Table Basic unit of storage; composed of rows View Logically represents subsets of data from

    one or more tablesSequence Generates numeric valuesIndex Improves the performance of some

    queriesSynonym Gives alternative names to objects

  • 1-94 Copyright 2004, Oracle. All rights reserved.

    What Is a View?EMPLOYEES table

  • 1-95 Copyright 2004, Oracle. All rights reserved.

    Advantages of Views

    To restrict data access

    To make complex queries easy

    To provide data

    independence

    To present different views of

    the same data

  • 1-96 Copyright 2004, Oracle. All rights reserved.

    Simple Views and Complex Views

    Feature Simple Views Complex ViewsNumber of tables One One or moreContain functions No YesContain groups of data No YesDML operations through a view

    Yes Not always

  • 1-97 Copyright 2004, Oracle. All rights reserved.

    Creating a View

    You embed a subquery in the CREATE VIEWstatement:

    The subquery can contain complex SELECTsyntax.

    CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view[(alias[, alias]...)]

    AS subquery[WITH CHECK OPTION [CONSTRAINT constraint]][WITH READ ONLY [CONSTRAINT constraint]];

  • 1-98 Copyright 2004, Oracle. All rights reserved.

    Creating a View

    Create the EMPVU80 view, which contains details of employees in department 80:

    Describe the structure of the view by using the SQL*Plus DESCRIBE command:

    DESCRIBE empvu80

    CREATE VIEW empvu80AS SELECT employee_id, last_name, salary

    FROM employeesWHERE department_id = 80;

    View created.

  • 1-99 Copyright 2004, Oracle. All rights reserved.

    Creating a View

    Create a view by using column aliases in the subquery:

    Select the columns from this view by the given alias names:

    CREATE VIEW salvu50AS SELECT employee_id ID_NUMBER, last_name NAME,

    salary*12 ANN_SALARYFROM employeesWHERE department_id = 50;

    View created.

  • 1-100 Copyright 2004, Oracle. All rights reserved.

    SELECT *FROM salvu50;

    Retrieving Data from a View

  • 1-101 Copyright 2004, Oracle. All rights reserved.

    Modifying a View

    Modify the EMPVU80 view by using a CREATE OR REPLACE VIEW clause. Add an alias for each column name:

    Column aliases in the CREATE OR REPLACE VIEWclause are listed in the same order as the columns in the subquery.

    CREATE OR REPLACE VIEW empvu80(id_number, name, sal, department_id)

    AS SELECT employee_id, first_name || ' ' || last_name, salary, department_id

    FROM employeesWHERE department_id = 80;

    View created.

  • 1-102 Copyright 2004, Oracle. All rights reserved.

    Creating a Complex View

    Create a complex view that contains group functions to display values from two tables:CREATE VIEW dept_sum_vu

    (name, minsal, maxsal, avgsal)AS SELECT d.department_name, MIN(e.salary),

    MAX(e.salary),AVG(e.salary)FROM employees e, departments dWHERE e.department_id = d.department_id GROUP BY d.department_name;

    View created.

  • 1-103 Copyright 2004, Oracle. All rights reserved.

    Rules for Performing DML Operations on a View

    You can usually perform DML operationson simple views.

    You cannot remove a row if the view contains the following: Group functions A GROUP BY clause The DISTINCT keyword The pseudocolumn ROWNUM keyword

  • 1-104 Copyright 2004, Oracle. All rights reserved.

    Rules for Performing DML Operations on a View

    You cannot modify data in a view if it contains: Group functions A GROUP BY clause The DISTINCT keyword The pseudocolumn ROWNUM keyword Columns defined by expressions

  • 1-105 Copyright 2004, Oracle. All rights reserved.

    Rules for Performing DML Operations on a View

    You cannot add data through a view if the view includes: Group functions A GROUP BY clause The DISTINCT keyword The pseudocolumn ROWNUM keyword Columns defined by expressions NOT NULL columns in the base tables that are not

    selected by the view

  • 1-106 Copyright 2004, Oracle. All rights reserved.

    Using the WITH CHECK OPTION Clause

    You can ensure that DML operations performed on the view stay in the domain of the view by using the WITH CHECK OPTION clause:

    Any attempt to change the department number for any row in the view fails because it violates the WITH CHECK OPTION constraint.

    CREATE OR REPLACE VIEW empvu20AS SELECT *

    FROM employeesWHERE department_id = 20WITH CHECK OPTION CONSTRAINT empvu20_ck ;

    View created.

  • 1-107 Copyright 2004, Oracle. All rights reserved.

    Denying DML Operations

    You can ensure that no DML operations occur by adding the WITH READ ONLY option to your view definition.

    Any attempt to perform a DML operation on any row in the view results in an Oracle server error.

  • 1-108 Copyright 2004, Oracle. All rights reserved.

    CREATE OR REPLACE VIEW empvu10(employee_number, employee_name, job_title)

    AS SELECT employee_id, last_name, job_idFROM employeesWHERE department_id = 10WITH READ ONLY ;

    View created.

    Denying DML Operations

  • 1-109 Copyright 2004, Oracle. All rights reserved.

    Removing a View

    You can remove a view without losing data because a view is based on underlying tables in the database.DROP VIEW view;

    DROP VIEW empvu80;View dropped.

  • 1-110 Copyright 2004, Oracle. All rights reserved.

    Practice 10: Overview of Part 1

    This practice covers the following topics: Creating a simple view Creating a complex view Creating a view with a check constraint Attempting to modify data in the view Removing views

  • 1-111 Copyright 2004, Oracle. All rights reserved.

    Sequences

    Object Description

    Table Basic unit of storage; composed of rows View Logically represents subsets of data from

    one or more tablesSequence Generates numeric valuesIndex Improves the performance of some

    queriesSynonym Gives alternative names to objects

  • 1-112 Copyright 2004, Oracle. All rights reserved.

    Sequences

    A sequence: Can automatically generate unique numbers Is a sharable object Can be used to create a primary key value Replaces application code Speeds up the efficiency of accessing sequence

    values when cached in memory

    12 4

    3 56 8

    710

    9

  • 1-113 Copyright 2004, Oracle. All rights reserved.

    CREATE SEQUENCE Statement:Syntax

    Define a sequence to generate sequential numbers automatically:CREATE SEQUENCE sequence

    [INCREMENT BY n][START WITH n][{MAXVALUE n | NOMAXVALUE}][{MINVALUE n | NOMINVALUE}][{CYCLE | NOCYCLE}][{CACHE n | NOCACHE}];

  • 1-114 Copyright 2004, Oracle. All rights reserved.

    Creating a Sequence

    Create a sequence named DEPT_DEPTID_SEQ to be used for the primary key of the DEPARTMENTStable.

    Do not use the CYCLE option.CREATE SEQUENCE dept_deptid_seq

    INCREMENT BY 10START WITH 120MAXVALUE 9999NOCACHENOCYCLE;

    Sequence created.

  • 1-115 Copyright 2004, Oracle. All rights reserved.

    NEXTVAL and CURRVAL Pseudocolumns

    NEXTVAL returns the next available sequence value. It returns a unique value every time it is referenced, even for different users.

    CURRVAL obtains the current sequence value. NEXTVAL must be issued for that sequence before

    CURRVAL contains a value.

  • 1-116 Copyright 2004, Oracle. All rights reserved.

    Using a Sequence

    Insert a new department named Support in location ID 2500:

    View the current value for the DEPT_DEPTID_SEQsequence:

    INSERT INTO departments(department_id, department_name, location_id)

    VALUES (dept_deptid_seq.NEXTVAL, 'Support', 2500);

    1 row created.

    SELECT dept_deptid_seq.CURRVALFROM dual;

  • 1-117 Copyright 2004, Oracle. All rights reserved.

    Caching Sequence Values

    Caching sequence values in memory gives faster access to those values.

    Gaps in sequence values can occur when: A rollback occurs The system crashes A sequence is used in another table

  • 1-118 Copyright 2004, Oracle. All rights reserved.

    Modifying a Sequence

    Change the increment value, maximum value, minimum value, cycle option, or cache option:

    ALTER SEQUENCE dept_deptid_seqINCREMENT BY 20MAXVALUE 999999NOCACHENOCYCLE;

    Sequence altered.

  • 1-119 Copyright 2004, Oracle. All rights reserved.

    Guidelines for Modifying a Sequence

    You must be the owner or have the ALTERprivilege for the sequence.

    Only future sequence numbers are affected. The sequence must be dropped and

    re-created to restart the sequence at a different number.

    Some validation is performed. To remove a sequence, use the DROP statement:DROP SEQUENCE dept_deptid_seq;Sequence dropped.

  • 1-120 Copyright 2004, Oracle. All rights reserved.

    Synonyms

    Object Description

    Table Basic unit of storage; composed of rows View Logically represents subsets of data from

    one or more tablesSequence Generates numeric valuesIndex Improves the performance of some

    queriesSynonym Gives alternative names to objects

  • 1-121 Copyright 2004, Oracle. All rights reserved.

    Synonyms

    Simplify access to objects by creating a synonym (another name for an object). With synonyms, you can: Create an easier reference to a table that is owned

    by another user Shorten lengthy object namesCREATE [PUBLIC] SYNONYM synonymFOR object;

  • 1-122 Copyright 2004, Oracle. All rights reserved.

    Creating and Removing Synonyms

    Create a shortened name for the DEPT_SUM_VU view:

    Drop a synonym:

    CREATE SYNONYM d_sumFOR dept_sum_vu;Synonym Created.

    DROP SYNONYM d_sum;Synonym dropped.

  • 1-123 Copyright 2004, Oracle. All rights reserved.

    Summary

    In this lesson, you should have learned how to: Create, use, and remove views Automatically generate sequence numbers by

    using a sequence generator Create indexes to improve query retrieval speed Use synonyms to provide alternative names for

    objects

  • 1-124 Copyright 2004, Oracle. All rights reserved.

    Practice 10: Overview of Part 2

    This practice covers the following topics: Creating sequences Using sequences Creating nonunique indexes Creating synonyms

  • 1-125 Copyright 2004, Oracle. All rights reserved.

  • 1-126 Copyright 2004, Oracle. All rights reserved.