pdf - e-book - archive

A.7  Comptes bancaires avec exceptions

DROP TABLE IF EXISTS OPERATION;
DROP TABLE IF EXISTS COMPTECLIENT;
DROP TABLE IF EXISTS TYPECCL;
DROP TABLE IF EXISTS TYPEOPERATION;
DROP TABLE IF EXISTS PERSONNEL;
DROP TABLE IF EXISTS CLIENT;

CREATE TABLE CLIENT
(numcli int,
 nomcli varchar(30),
 prenomcli varchar(30),
 adresse varchar(60),
 tel varchar(10)
);

CREATE TABLE PERSONNEL
(numpers int,
 nompers varchar(30),
 prenompers varchar(30),
 manager int,
 salaire int
);

CREATE TABLE TYPECCL
(numtypeccl int,
 nomtypeccl varchar(30)
);

CREATE TABLE COMPTECLIENT
(numcli int,
 numccl int,
 numtypeccl int,
 dateccl date default sysdate not null,
 numpers int
);

CREATE TABLE TYPEOPERATION
(numtypeoper int,
 nomtypeoper varchar(30)
);

CREATE TABLE OPERATION
(numcli int,
 numccl int,
 numoper int,
 numtypeoper int,
 dateoper date,
 montantoper int not null,
 libeloper varchar(30)
);

ALTER TABLE CLIENT ADD
        (
        CONSTRAINT pk_client PRIMARY KEY (numcli),
        CONSTRAINT ck_telephone CHECK(LENGTH(tel)=10)
        );

ALTER TABLE PERSONNEL ADD
        (
        CONSTRAINT pk_personnel PRIMARY KEY (numpers),
        CONSTRAINT ck_salaire CHECK(SALAIRE >= 1254.28)
        );

ALTER TABLE TYPECCL ADD
        CONSTRAINT pk_typeccl PRIMARY KEY (numtypeccl);

ALTER TABLE TYPEOPERATION ADD
        CONSTRAINT pk_typeoperation PRIMARY KEY (numtypeoper);

ALTER TABLE COMPTECLIENT ADD
        (
        CONSTRAINT pk_compteclient
                PRIMARY KEY (numcli, numccl),
        CONSTRAINT fk_ccl_typeccl
                FOREIGN KEY (numtypeccl)
                REFERENCES TYPECCL (numtypeccl),
        CONSTRAINT fk_ccl_client
                FOREIGN KEY (numcli)
                REFERENCES CLIENT (numcli),
        CONSTRAINT fk_ccl_personnel
                FOREIGN KEY (numpers)
                REFERENCES PERSONNEL (numpers)
        );

ALTER TABLE OPERATION ADD
        (
        CONSTRAINT pk_operation
                PRIMARY KEY (numcli, numccl, numoper),
 CONSTRAINT fk_oper_ccl
  FOREIGN KEY (numcli, numoper)
  REFERENCES COMPTECLIENT (numcli, numccl),
        CONSTRAINT fk_oper_codeoper
                FOREIGN KEY (numtypeoper)
                REFERENCES typeoperation (numtypeoper),
 CONSTRAINT montant_operation 
  CHECK(montantoper <> 0 AND montantoper >= -1000 AND montantoper <= 1000)
        );

INSERT INTO TYPECCL VALUES (
 (SELECT nvl(MAX(numtypeccl), 0) + 1 
 FROM TYPECCL
 ),
'Compte courant');

INSERT INTO TYPECCL VALUES (
 (SELECT nvl(MAX(numtypeccl), 0) + 1 
 FROM TYPECCL
 ),
'livret');

INSERT INTO TYPECCL VALUES (
 (SELECT nvl(MAX(numtypeccl), 0) + 1 
 FROM TYPECCL
 ),
'PEL');

INSERT INTO TYPEOPERATION VALUES (
 (SELECT nvl(MAX(numtypeoper), 0) + 1 
 FROM TYPEOPERATION
 ),
'dépôt espèces');

INSERT INTO TYPEOPERATION VALUES (
 (SELECT nvl(MAX(numtypeoper), 0) + 1 
 FROM TYPEOPERATION
 ),
'prélèvement');

INSERT INTO TYPEOPERATION VALUES (
 (SELECT nvl(MAX(numtypeoper), 0) + 1 
 FROM TYPEOPERATION
 ),
'virement');

INSERT INTO TYPEOPERATION VALUES (
 (SELECT nvl(MAX(numtypeoper), 0) + 1 
 FROM TYPEOPERATION
 ),
'retrait');

Télécharger le fichier