ORACLE - создание нескольких таблиц с одинаковыми именами столбцов - PullRequest
0 голосов
/ 06 февраля 2020

Я пытаюсь создать 8 таблиц: КАТЕГОРИИ ЗАКАЗЧИКИ СОТРУДНИКИ ПРОДУКТЫ ЗАКАЗЫ ГРУППЫ ПОСТАВЩИКОВ ПОСТАВЩИКИ ПОСТАВЩИКОВ

Некоторые из них будут иметь идентичные имена столбцов, например CompanyName в поставщиках, а также в клиентах.

Однако, когда я запускаю код, он выдает мне ошибки:

ORA-00907: отсутствует правая скобка или: ORA-00955: имя уже используется существующим объектом

Как бы я go вокруг этого?

below is my code:

    CREATE TABLE CATEGORIES 
(

    CATEGORYID NUMBER(8,0),
    CATEGORYNAME VARCHAR2(15) NOT NULL,
    CATEGORYCODE NUMBER(6,0),
    DESCRIPTION VARCHAR2(300),
    CONSTRAINT CATEGORIES_CATEGORYID_PK PRIMARY KEY (CATEGORYID)
);


CREATE TABLE CUSTOMERS 
(
    CUSTOMERID CHAR(5),
    COMPANYNAME VARCHAR2(40) NOT NULL,
    CONTACTNAME VARCHAR2(30),
    CONTACTTITLE VARCHAR2(30),
    ADDRESS VARCHAR2(30),
    CITY VARCHAR2(15),
    REGION VARCHAR2(15),
    POSTALCODE VARCHAR2(10),
    COUNTRY VARCHAR2(15),
    PHONE VARCHAR2(24),
    FAX VARCHAR2(24),
    EMAIL VARCHAR2(50),
    CONSTRAINT CUSTOMERS_CUSTOMERID_PK PRIMARY KEY(CUSTOMERID) 
);


CREATE TABLE EMPLOYEES
(
    EMPLOYEEID NUMBER(8,0),
    LASTNAME VARCHAR2(20) NOT NULL,
    FIRSTNAME VARCHAR2(10) NOT NULL,
    TITLE VARCHAR2(30),
    TITLEOFCOURTESY VARCHAR2(25),
    BIRTHDATE DATE(7),
    HIREDATE DATE(7),
    ADDRESS VARCHAR2(60),
    CITY VARCHAR2(15),
    REGION VARCHAR2(15),
    POSTALCODE VARCHAR2(10),
    COUNTRY VARCHAR2(15),
    HOMEPHONE VARCHAR2(24),
    EXTENSION VARCHAR2(4),
    NOTES VARCHAR2(600),
    REPORTSTO NUMBER(8,0),
    SIN CHAR(9),
    CONSTRAINT EMLOYEES_EMPLOYEEID_PK PRIMARY KEY(EMPLOYEEID)


);


CREATE TABLE ORDERDETAILS
(
    ORDERID NUMBER(8,0),
    PRODUCTID NUMBER(8,0),
    UNITPRICE NUMBER(8,2) NOT NULL,
    QUANTITY NUMBER(6,0) NOT NULL,
    DISCOUNT NUMBER(2,2) NOT NULL,
CONSTRAINT ORDERDETAILS_ORDERID_PRODUCTID_PK PRIMARY KEY (ORDERID, PRODUCTID)

);


CREATE TABLE ORDERS
(
    ORDERID NUMBER(8,0),
    CUSTOMERID CHAR(5),
    EMPLOYEEID NUMBER(22),
    TERRITORYID VARCHAR2(20),
    ORDERDATE DATE(7),
    REQUIREDATE DATE(7),
    SHIPPEDDATE DATE(7),
    SHIPVIA NUMBER(8,0),
    FREIGHT NUMBER(8,2),
    SHIPNAME VARCHAR2(40),
    SHIPADDRESS VARCHAR2(60),
    SHIPCITY VARCHAR2(15),
    SHIPREGION VARCHAR2(15),
    SHIPPOSTALCODE VARCHAR2(10),
    SHIPCOUNTRY VARCHAR2(15),
    CONSTRAINT ORDERS_ORDERID_PK PRIMARY KEY(ORDERID),
    CONSTRAINT ORDERS_CUSTOMERID_FK FOREIGN KEY (CUSTOMERID) 
    REFERENCES CUSTOMERS(CUSTOMERID),
    CONSTRAINT ORDERS_EMPLOYEEID_FK FOREIGN KEY (EMPLOYEEID) 
    REFERENCES EMPLOYEES(EMPLOYEEID)
);


CREATE TABLE PRODUCTS
(
    PRODUCTID NUMBER(8,0),
    PRODUCTNAME VARCHAR2(4) NOT NULL,
    SUPPLIERID NUMBER(8,0),
    CATEGORYID NUMBER(8,0),
    QUANTITYPERUNIT VARCHAR2(20),
    UNITPRICE NUMBER(8,2),
    UNITSINSTOCK NUMBER(6,0),
    UNITSONORDER NUMBER(6,0),
    REORDERLEVEL NUMBER(6,0),
    DISCONTINUED NUMBER(1,0) NOT NULL,
    CONSTRAINT PRODUCTS_CATEGORYID_FK FOREIGN KEY (CATEGORYID)
    REFERENCES CATEGORIES(CATEGORYID),
    CONSTRAINT PRODUCTS_SUPPLIERID_FK FOREIGN KEY (SUPPLIERID)
    REFERENCES SUPPLIERS(SUPPLIERID)

);

CREATE TABLE SUPPLIERS
(
    SUPPLIERID NUMBER(8,0),
    COMPANYNAME VARCHAR2(40) NOT NULL,
    CONTACTNAME VARCHAR2(30),
    CONTACTTITLE VARCHAR2(30),
    ADDRESS VARCHAR2(60),
    CITY VARCHAR2(15),
    REGION VARCHAR2(15),
    POSTALCODE VARCHAR2(10),
    COUNTRY VARCHAR2(15),
    PHONE VARCHAR2(24),
    FAX VARCHAR2(24),
    HOMEPAGE VARCHAR(200),
    CONSTRAINT SUPPLIERS_SUPPLIERID_PK PRIMARY KEY(SUPPLIERID)

);


CREATE TABLE SHIPPERS
(
    SHIPPERID NUMBER(8,0),
    COMPANYNAME VARCHAR2(40) NOT NULL,
    PHONE VARCHAR2(24),
    CONSTRAINT SHIPPERS_SHIPPERID_PK PRIMARY KEY(SHIPPERID)


);

Ответы [ 2 ]

1 голос
/ 06 февраля 2020

В вашем коде есть три проблемы:

  1. Если вы используете oracle12 c или выше, то допускаются имена объектов длиной 128 символов. Если вы используете oracle 11g или ниже, то допускаются только 30 символов. Вам следует рассмотреть возможность изменения имени ограничения: ORDERDETAILS_ORDERID_PRODUCTID_PK, чтобы оно не превышало 30 символов.

  2. Вы использовали тип данных даты как DATE(7), но в oracle date Тип данных не имеет параметра длины. Поэтому используйте DATE без длины данных, т.е. (7)

  3. Создайте SUPPLIERS таблицу перед PRODUCTS таблицей, так как PRODUCTS таблица ссылается на таблицу SUPPLIERS.

См. db <> fiddle demo

Cheers !!

0 голосов
/ 06 февраля 2020

J

Выполните это ниже: Он фиксирует тип данных даты и заказ между поставщиком и продуктами и, наконец, длину ограничения ORDERDETAILS_ORDERID_PRODUCTID_PK

    CREATE TABLE CATEGORIES 
(

    CATEGORYID NUMBER(8,0),
    CATEGORYNAME VARCHAR2(15) NOT NULL,
    CATEGORYCODE NUMBER(6,0),
    DESCRIPTION VARCHAR2(300),
    CONSTRAINT CATEGORIES_CATEGORYID_PK PRIMARY KEY (CATEGORYID)
);


CREATE TABLE CUSTOMERS 
(
    CUSTOMERID CHAR(5),
    COMPANYNAME VARCHAR2(40) NOT NULL,
    CONTACTNAME VARCHAR2(30),
    CONTACTTITLE VARCHAR2(30),
    ADDRESS VARCHAR2(30),
    CITY VARCHAR2(15),
    REGION VARCHAR2(15),
    POSTALCODE VARCHAR2(10),
    COUNTRY VARCHAR2(15),
    PHONE VARCHAR2(24),
    FAX VARCHAR2(24),
    EMAIL VARCHAR2(50),
    CONSTRAINT CUSTOMERS_CUSTOMERID_PK PRIMARY KEY(CUSTOMERID) 
);


CREATE TABLE EMPLOYEES
(
    EMPLOYEEID NUMBER(8,0),
    LASTNAME VARCHAR2(20) NOT NULL,
    FIRSTNAME VARCHAR2(10) NOT NULL,
    TITLE VARCHAR2(30),
    TITLEOFCOURTESY VARCHAR2(25),
    BIRTHDATE DATE,
    HIREDATE DATE,
    ADDRESS VARCHAR2(60),
    CITY VARCHAR2(15),
    REGION VARCHAR2(15),
    POSTALCODE VARCHAR2(10),
    COUNTRY VARCHAR2(15),
    HOMEPHONE VARCHAR2(24),
    EXTENSION VARCHAR2(4),
    NOTES VARCHAR2(600),
    REPORTSTO NUMBER(8,0),
    SIN CHAR(9),
    CONSTRAINT EMLOYEES_EMPLOYEEID_PK PRIMARY KEY(EMPLOYEEID)


);


CREATE TABLE ORDERDETAILS
(
    ORDERID NUMBER(8,0),
    PRODUCTID NUMBER(8,0),
    UNITPRICE NUMBER(8,2) NOT NULL,
    QUANTITY NUMBER(6,0) NOT NULL,
    DISCOUNT NUMBER(2,2) NOT NULL,
CONSTRAINT ORDERDETLS_ORDRID_PRODID_PK PRIMARY KEY (ORDERID, PRODUCTID)

);


CREATE TABLE ORDERS
(
    ORDERID NUMBER(8,0),
    CUSTOMERID CHAR(5),
    EMPLOYEEID NUMBER(22),
    TERRITORYID VARCHAR2(20),
    ORDERDATE DATE,
    REQUIREDATE DATE,
    SHIPPEDDATE DATE,
    SHIPVIA NUMBER(8,0),
    FREIGHT NUMBER(8,2),
    SHIPNAME VARCHAR2(40),
    SHIPADDRESS VARCHAR2(60),
    SHIPCITY VARCHAR2(15),
    SHIPREGION VARCHAR2(15),
    SHIPPOSTALCODE VARCHAR2(10),
    SHIPCOUNTRY VARCHAR2(15),
    CONSTRAINT ORDERS_ORDERID_PK PRIMARY KEY(ORDERID),
    CONSTRAINT ORDERS_CUSTOMERID_FK FOREIGN KEY (CUSTOMERID) 
    REFERENCES CUSTOMERS(CUSTOMERID),
    CONSTRAINT ORDERS_EMPLOYEEID_FK FOREIGN KEY (EMPLOYEEID) 
    REFERENCES EMPLOYEES(EMPLOYEEID)
);


CREATE TABLE SUPPLIERS
(
    SUPPLIERID NUMBER(8,0),
    COMPANYNAME VARCHAR2(40) NOT NULL,
    CONTACTNAME VARCHAR2(30),
    CONTACTTITLE VARCHAR2(30),
    ADDRESS VARCHAR2(60),
    CITY VARCHAR2(15),
    REGION VARCHAR2(15),
    POSTALCODE VARCHAR2(10),
    COUNTRY VARCHAR2(15),
    PHONE VARCHAR2(24),
    FAX VARCHAR2(24),
    HOMEPAGE VARCHAR(200),
    CONSTRAINT SUPPLIERS_SUPPLIERID_PK PRIMARY KEY(SUPPLIERID)

);


CREATE TABLE PRODUCTS
(
    PRODUCTID NUMBER(8,0),
    PRODUCTNAME VARCHAR2(4) NOT NULL,
    SUPPLIERID NUMBER(8,0),
    CATEGORYID NUMBER(8,0),
    QUANTITYPERUNIT VARCHAR2(20),
    UNITPRICE NUMBER(8,2),
    UNITSINSTOCK NUMBER(6,0),
    UNITSONORDER NUMBER(6,0),
    REORDERLEVEL NUMBER(6,0),
    DISCONTINUED NUMBER(1,0) NOT NULL,
    CONSTRAINT PRODUCTS_CATEGORYID_FK FOREIGN KEY (CATEGORYID)
    REFERENCES CATEGORIES(CATEGORYID),
    CONSTRAINT PRODUCTS_SUPPLIERID_FK FOREIGN KEY (SUPPLIERID)
    REFERENCES SUPPLIERS(SUPPLIERID)

);


CREATE TABLE SHIPPERS
(
    SHIPPERID NUMBER(8,0),
    COMPANYNAME VARCHAR2(40) NOT NULL,
    PHONE VARCHAR2(24),
    CONSTRAINT SHIPPERS_SHIPPERID_PK PRIMARY KEY(SHIPPERID)


);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...