Tuesday, 18 February 2014

Constraints

Data Integrity Rules { Constraints }:

 A set of pre-defined rules applied on table columns while creating Tables or after creation.

 They are automatically activated when ever "DML" operations are performed on tables.

 They are used to impose restrictions on Table Columns.

 They are also activated when Tables are manipulated by other users or by other Application  s/w Tools.

 They provide High security on Tables.

 3 Types
 1. Domain Integrity Rules
    Used to restrict duplicate values into table columns.
    ex: Unique , Primary Key

 2. Entity Integrity Rules
    Used to provide conditional restrictions on Table columns.    
    ex: Check , Not null

 3. Referential Integrity Rule
    Used to establish relationship between 2 tables.
    ex: References ( Foreign Key )

 Oracle Constraints :
 * Not null : Used to restrict null values , Any no.of duplicates are allowed. ( Column Level                                                            Constraint )

 * Unique : Used to restrict duplicate values but any no.of null values are allowed.
       ( 2 null values are not equal )

 * Check : Used to provide conditional restrictions on table columns.

 * Default : Used define initail value for a column
     ( Column Level property ).
    If column is not assigned with a value then default value will be accepted.

 * Primary Key :  Not Null + Unique + Index
    Used to define the Key column of a table.
    It can be used only once in Table definition.
    It will not allow Null values and Duplicate values into Key column.
    It is supported with an Index automatically.

  Index :
  It is a pointer locates the physical address of data.
  It will improve performance of oracle while Retrieving or Manipulating data using Key column.
  It is automatically activated whenever key column is used in "Where" clause.

 * References ( Foreign Key ) :
   Used to define relationship between 2 Tables.
   It allows Null and duplicate values .
   It can be related to either Primary key or unique constraint column of other Table.
   PK / UNQ  <----->  FK

  T1                    T2
  --- ---
  c1 (pk/unq)     c1 (fk)     T1.c1 = T2.c1
---------------------------------------------------------------
 dept emp
 ------ ------
 deptno (pk)   deptno (fk)

  dept.deptno = emp.deptno
* one - many or many - one Relation established
    between PK and FK.                        
---------------------------------------------------------------
 Note:
 Constraints are defined in 2 Methods:
 1. Column Constraint Syntax
 2. Table Constraint Syntax

 1. Column Constraint Syntax
 constraints are defined at the end of column  definition.
 All constraints are supported.
 Used to define constraints only while creating  Tables    

 Using Column constraint Syntax:
 create table dept
 (deptno number(2) primary key,
 dname varchar2(20) not null unique,
 loc varchar2(20) default 'Hyderabad');

 insert into dept values (10,'SALES','MUMBAI');
 insert into dept values (null,'HR','PUNE');
 insert into dept values (10,'ADMIN','NOIDA');
 insert into dept values (20, null ,'Secbad');
 insert into dept values (30,'Sales','GOA');
---------------------------------------------------------------
 Activating default :
 insert into dept values(40,'TRAINING',default);
 * Default : keyword (8.0)
 used to replace with default value defined

 insert into dept(deptno,dname) values(50,'TESTING');
 insert into dept values(60,'RESEARCH',null);
 insert into dept values(70,'HR'); -- error
 select * from dept;
 40  TRAINING   Hyderabad
 50  TESTING     Hyderabad
 60  RESEARCH
---------------------------------------------------------------
 select * from dept where deptno = 10;
 update dept set loc = 'VIZAG' where deptno = 30;
 -- Index is activated automatically while Retrieving or Manipulating data thru key column in WHERE clause.
---------------------------------------------------------------
 Create table emp
 (empno number(4) primary key,
 ename varchar2(20) not null,
 sex char(1) check (sex in ('M','F')),
 sal number(12,2) check (sal >= 5000),
 hiredate date default sysdate,
 mail_id varchar2(100) unique,
 deptno number(2)
 references dept on delete cascade );

  * emp.deptno = dept.deptno -- Join condition
  dept - Master Table (parent) -- Independent Table
  emp - Detail Table (child) --  Dependent Table    

 * dept - deptno (10,20,30,40)
 insert into emp values(101,...........,10);
 insert into emp values(102,...........,20);
 insert into emp values(103,...........,30);
 insert into emp values(104,...........,10);
 insert into emp values(105,...........,10);
 insert into emp values(108,...........,null);
 insert into emp values(110,...........,90); -- error
 err: Parent key not found (2291)

 delete from dept where deptno = 10; -- error
 err: Depending child rows exists - cannot remove parent ( 2292 )

 create table incr(empno number(4) not null
 references emp  on delete cascade ,
 amt number(10,2) not null);

 incr.empno = emp.empno -- Join Condition

 insert into incr values(101,10000);
 insert into incr values(105,10000);
 insert into incr values(103,5000);
 insert into incr values(105,5000);
 insert into incr values(null,10000); -- error (null value)
 insert into incr values(999,10000); -- error
  err: Parent key not found

 insert delete
    1 Dept    3
      |
    2 Emp    2
    |
    3 Incr       1


 If  " On delete cascade " is not defined :
 3. delete from dept where deptno = 10;
 err - depending child rows exists
 2. delete from emp where deptno = 10;
 err - depending child rows exists
 1. delete from incr where empno in
 ( select empno from emp where deptno = 10);

 On delete cascade - Clause
 Automatically removes the child rows whenever parent record is removed.
 It has to be specified with every child table along with references constraint.
 It cannot be assigned seperately.
 It is activated by " Delete " stmt on parent table.

 If On delete cascade is defined :
 >delete from dept where deptno = 10;
 -- Automatically removes dept 10 details from Emp, incr tables also.

  drop table dept;
  error : depending child rows exists

  drop table dept cascade constraints;

 Cascade constraints - clause
 Allows to remove the parent table even if child exists.
 It will destroy the relationship between 2 tables.
 Child records still exists even if parent table is dropped.
 It is used with "drop" stmt on parent table.

 Oracle Constraint Error Nos:
 Not null   --->  -1400
 Unique    --->   -1
 Check      --->   -2290
 References  --->  -2291 -- Parent key not found
                            -2292 -- Depending child rows exists
---------------------------------------------------------------
 create table stu_info( roll number(3) primary key,
 sname varchar2(20) not null,
 course varchar2(10)
 check (course in ('oracle' , 'dwh' , 'unix' , 'd6i')),
 fee number(5) check (fee >= 1000),
 doj date default sysdate);

 insert into stu_info values(101,'RAM','oracle',1000,sysdate);
 update stu_info set fee = 500 where roll = 101;
  -- error
---------------------------------------------------------------
 create table course (cid char(6) primary key,
 cname varchar2(20) not null,
 faculty varchar2(20) not null,
  room number(3),
  start_date date);

 ora10  oracle 11g  Sridhar  511 28-feb-11

 create table student(roll number(3) primary key,
 sname varchar2(20) not null,
 sex char(1) check (sex in ('M','F')),
 cid char(6) references course,
 email varchar2(30) unique,
 fee number(5) check (fee >= 1000));

 101 RAM M ora10 ram@gmail.com 2100

 course.cid = student.cid --- join condition

create table fee_instalments
(roll number(3) not null references student ,
  amt number(5) not null , date_paid date);

 101  1000  28-feb-11
 101  500    15-mar-11
 101  600     30-mar-11

student.roll = fee_instalments.roll -- join condition

* Course  -->  student  -->  fee_instalments
---------------------------------------------------------------
 Table constraint syntax:
 Constraints are defined at the end of table definition.
 Supports to define Composite Primary key(CPK) and Composite Foreign key (CFK).
 Not null and Default are not allowed.
 Used to define constraints on existing tables.
 Max 32 columns can be defined in CPK or CFK.

 Ex:  Create table Reservation
        ( train_no number(4) ,
          coach_id varchar2(5) ,
         seat_no number(3) ,
         doj date ,  pname varchar2(20),
         age number(3),  sex char(1),
         to_stn varchar2(20), from_stn varchar2(20),
         fare number(5),
   constraint pk_rail
   primary key (train_no, coach_id, seat_no, doj));

  7025         7025               101 - oracle - 10:00
  S1               S1                101 - oracle - 11:30
  10               11                 102 - oracle - 10:00
 16-MAY-11   16-MAY-11   (roll - course - timing ) --- CPK
--------------------------------------------------------------
 create table bankmaster
 ( accno number(4), acc_type char(1),
  name varchar2(20) not null,
  curr_bal number(12,2),
  pan_no varchar2(15) ,
 constraint pk_bank primary key(accno,acc_type),
 constraint chk_atype check (acc_type in('S','C','R')),
 constraint chk_bal check (curr_bal >= 5000),
 constraint unq_pan unique(pan_no));

 101  101  101   102  101  null  103
  S      R      C     null    S      S     r

  create table Transaction
  ( accno number(4), acc_type char(1),
  tran_type char(1), tran_date date default sysdate,
  amt number(12,2),
  constraint fk_bank foreign key (accno,acc_type) references bankmaster on delete cascade,
  constraint chk_ttype check (tran_type in ('W','D')),
  constraint chk_amt check (amt >= 100));

  Join condition :
  bankmaster.accno = transaction.accno and
  bankmaster.acc_type = transaction.acc_type
---------------------------------------------------------------
 Adding Constraints to existing Tables:

 Alter table dept add constraint pk_dept
 primary key(deptno);
 Alter table dept add constraint unq_dname unique(dname);
 Alter table emp add constraint pk_emp
 primary key(empno);
 Alter table emp add constraint chk_sal
 check(sal >= 3000);

 Alter table emp add constraint fk_dept
 foreign key(deptno)
 references dept(deptno) on delete cascade;

 Note:
 * While adding constraints to existing tables with information existing data must satisfy constraint Rule.

 Adding Not null & Default : ( Properties )
 Alter table emp modify ename varchar2(20)
 not null;
 Alter table emp modify hiredate date default sysdate;

 Removing Not null & Default : ( Properties )
 Alter table emp modify ename varchar2(20) null;
 Alter table emp modify hiredate date default null;

[ drop/disable/enable ]
 Alter table <table name> drop constraint
 <cons name>;
 Alter table emp disable constraint chk_sal;
 Alter table emp enable constraint chk_sal;
 Alter table emp drop constraint chk_sal;
---------------------------------------------------------------
 Scott: ( Sharing Constraints )
 Grant References on dept to user1;

 User1:
 Create table employ (
 empno number(4) constraint pk_emp primary key,
 ename varchar2(20), sal number(12,2),
 * mgr number(4) References employ,
 deptno number(2) references scott.dept);

 insert into employ values(101,......,null,10);
 insert into employ values(102,......,101,10);

 Join Conditions :
 employ.empno = employ.mgr ( Self Join )
 user1.employ.deptno = scott.dept.deptno

 * Self Reference Key: (mgr)
    Table Referencing to itself.
     Same table acts as a Parent to itself .
    Table must have similar column to apply this relation.
---------------------------------------------------------------
 create table emp (empno number(4) primary key,     .....);

 Removing Primary Key:
 Alter table emp drop constraint sys_c002345 ;

   System Tables:
 * User_constraints --- Holds the complicate details of constraints defined on table columns.

 * User_cons_columns --- Holds the brief information about the constraints applied on table    columns.

 > desc user_constraints
 > select * from user_constraints
    where table_name = 'EMP';
 > select constraint_name, constraint_type from user_constraints where table_name = 'EMP';

 sys_c002345    P (PK)
 sys_c002346    C (Chk / NN )
 sys_c002347    U (Unq)
 sys_c002348    R (Ref)

 > desc user_cons_columns
 > select * from user_cons_columns
    where table_name = 'EMP';
---------------------------------------------------------------
  * Display common column between 2 tables
 select column_name from user_tab_columns
 where table_name = 'DEPT'
 intersect
 select column_name from user_tab_columns
 where table_name = 'EMP' ;
---------------------------------------------------------------

No comments:

Post a Comment