Sql 在不违反主键和唯一约束的情况下更改表结构

Sql 在不违反主键和唯一约束的情况下更改表结构,sql,database,oracle,constraints,primary-key,Sql,Database,Oracle,Constraints,Primary Key,是我拥有的一个逻辑模型 下表为结构及其约束条件 医生 CREATE TABLE doctor ( doctor_id NUMBER(4) NOT NULL, doctor_title VARCHAR2(2) NOT NULL, doctor_fname VARCHAR2(50), doctor_lname VARCHAR2(50), doctor_phone CHAR(10) NOT NULL ); ALTER TABLE doc

是我拥有的一个逻辑模型

下表为结构及其约束条件

医生

CREATE TABLE doctor (
    doctor_id      NUMBER(4) NOT NULL,
    doctor_title   VARCHAR2(2) NOT NULL,
    doctor_fname   VARCHAR2(50),
    doctor_lname   VARCHAR2(50),
    doctor_phone   CHAR(10) NOT NULL
);
ALTER TABLE doctor ADD CONSTRAINT doctor_pk PRIMARY KEY ( doctor_id );
程序

CREATE TABLE procedure (
    proc_code          NUMBER(5) NOT NULL,
    proc_name          VARCHAR2(100) NOT NULL,
    proc_description   VARCHAR2(300) NOT NULL,
    proc_time          NUMBER(3) NOT NULL,
    proc_std_cost      NUMBER(7, 2) NOT NULL
);

ALTER TABLE procedure ADD CONSTRAINT procedure_pk PRIMARY KEY ( proc_code );

ALTER TABLE procedure ADD CONSTRAINT proc_name_unq UNIQUE ( proc_name );
CREATE TABLE adm_prc (
    adprc_no           NUMBER(7) NOT NULL,
    adprc_date_time    DATE NOT NULL,
    adprc_pat_cost     NUMBER(7, 2) NOT NULL,
    adprc_items_cost   NUMBER(6, 2) NOT NULL,
    adm_no             NUMBER(6) NOT NULL,
    proc_code          NUMBER(5) NOT NULL,
    request_dr_id      NUMBER(4) NOT NULL,
    perform_dr_id      NUMBER(4)
);
ALTER TABLE adm_prc ADD CONSTRAINT adm_prc_pk PRIMARY KEY ( adprc_no );    --surrogate key
ALTER TABLE adm_prc ADD CONSTRAINT adm_prc_nk UNIQUE ( adprc_date_time,
                                                       adm_no );
ALTER TABLE adm_prc
    ADD CONSTRAINT admission_admprc FOREIGN KEY ( adm_no )
        REFERENCES admission ( adm_no );
ALTER TABLE adm_prc
    ADD CONSTRAINT doctor_performadmprc FOREIGN KEY ( perform_dr_id )
        REFERENCES doctor ( doctor_id );
ALTER TABLE adm_prc
    ADD CONSTRAINT doctor_requestadmprc FOREIGN KEY ( request_dr_id )
        REFERENCES doctor ( doctor_id );
接纳

CREATE TABLE admission (
    adm_no          NUMBER(6) NOT NULL,
    adm_date_time   DATE NOT NULL,
    adm_discharge   DATE,
    patient_id      NUMBER(6) NOT NULL,
    doctor_id       NUMBER(4) NOT NULL
);

ALTER TABLE admission ADD CONSTRAINT admission_pk PRIMARY KEY ( adm_no );    --surrogate key

ALTER TABLE admission ADD CONSTRAINT admission_nk UNIQUE ( patient_id,
                                                           adm_date_time );
入院程序

CREATE TABLE adm_prc (
    adprc_no           NUMBER(7) NOT NULL,
    adprc_date_time    DATE NOT NULL,
    adprc_pat_cost     NUMBER(7, 2) NOT NULL,
    adprc_items_cost   NUMBER(6, 2) NOT NULL,
    adm_no             NUMBER(6) NOT NULL,
    proc_code          NUMBER(5) NOT NULL,
    request_dr_id      NUMBER(4) NOT NULL,
    perform_dr_id      NUMBER(4)
);
ALTER TABLE adm_prc ADD CONSTRAINT adm_prc_pk PRIMARY KEY ( adprc_no );    --surrogate key
ALTER TABLE adm_prc ADD CONSTRAINT adm_prc_nk UNIQUE ( adprc_date_time,
                                                       adm_no );
ALTER TABLE adm_prc
    ADD CONSTRAINT admission_admprc FOREIGN KEY ( adm_no )
        REFERENCES admission ( adm_no );
ALTER TABLE adm_prc
    ADD CONSTRAINT doctor_performadmprc FOREIGN KEY ( perform_dr_id )
        REFERENCES doctor ( doctor_id );
ALTER TABLE adm_prc
    ADD CONSTRAINT doctor_requestadmprc FOREIGN KEY ( request_dr_id )
        REFERENCES doctor ( doctor_id );
项目处理

CREATE TABLE item_treatment (
    adprc_no             NUMBER(7) NOT NULL,
    item_code            CHAR(5) NOT NULL,
    it_qty_used          NUMBER(2) NOT NULL,
    it_item_total_cost   NUMBER(8, 2) NOT NULL
);

ALTER TABLE item_treatment
    ADD CONSTRAINT item_treatment_pk PRIMARY KEY ( adprc_no,item_code);
ALTER TABLE item_treatment
    ADD CONSTRAINT admprc_itemtreatment FOREIGN KEY ( adprc_no )
        REFERENCES adm_prc ( adprc_no );
ALTER TABLE item_treatment
    ADD CONSTRAINT admprc_itemtreatment FOREIGN KEY ( adprc_no )
        REFERENCES adm_prc ( adprc_no );
ALTER TABLE item_treatment
    ADD CONSTRAINT item_itemtreatment FOREIGN KEY ( item_code )
        REFERENCES item ( item_code );
在虚拟医院中,每次完成患者入院的入院程序时,执行该程序的主治医生都会记录在
adm\u prc
表中的
perform\u dr\u id
下。即使由一组医生进行手术,也只记录主治医生

医院现在希望记录所有在入院程序中执行的医生,包括一名辅助医生(辅助医生)

我已更改了“行政-中华人民共和国”表,以包括辅助医生

ALTER TABLE ADM_PRC ADD ANCILLARY_DR_ID NUMBER(4);
ALTER TABLE ADM_PRC
    ADD CONSTRAINT DOCTOR_PERFORM_ANCILLARY FOREIGN KEY ( ANCILLARY_DR_ID )
        REFERENCES DOCTOR ( DOCTOR_ID );
我需要改变数据库的结构,因为在一个入院过程中可能会有很多医生协助,所以同一个入院过程应该有多个记录。例如,我应该能够在
adm\u prc
表中插入以下记录

adprc_no  adprc_date_time  adprc_pat_cost  adprc_items_cost  adm_no  proc_code 
 request_dr_id  perform_dr_id  ancillary_dr_id
-----------------------------------------------------------------------------------------------------------------------------
1         14/03/2019       100             100               1234    1234         
 10             10             12
1         14/03/2019       100             100               1234    1234         
 10             10             13
但是,这违反了主键约束
adm\u prc\u pk


我被困在这一点上,无法继续前进。如果有人能给我指出正确的方向,我将不胜感激。

您应该创建一个新的卫星表(比如ADM\u PRC\u DR\u DTLS),以保存adprc\u编号和相应的DR\u id详细信息。
ADM_PRC_DR_DTLS的adprc_编号将ADM_PRC的adprc_编号作为外键引用。

由于入院与辅助医生之间没有n:1对应关系,您不应在入院中添加列,而应创建一个新的详细信息表(表示fk到入院中),在该表中您可以保存每次入院的多个记录(每名助理医生一名)。谢谢你的建议。毕竟我必须创建一个新表。不知何故,我没有看到它。非常值得赞赏的是,这是有效的。通过创建一个新表ADM_PRC_DR_DTLS,ADM_PRC_no作为外键,doctor_id作为外键。我将两列作为主键,现在对于同一个adprc_no,我可以有许多纤毛医生,谢谢!