Попытка запустить скрипт через Oracle 11g - PullRequest
0 голосов
/ 21 апреля 2020

Я пытаюсь выполнить SQL операторы в Oracle 11g Express издании, где я должен создавать таблицы. Вот мой SQL код:

    CREATE TABLE STORE
    (
    StoreID INT PRIMARY KEY,
    StoreName VARCHAR2(30) NOT NULL,
    City VARCHAR2(30) NOT NULL,
    Country VARCHAR2(30) NOT NULL CHECK Country in ('China','Egypt','United States','Spain','New Zealand','Mexico','Africa'),
    Phone VARCHAR2(30) NOT NULL,
    Fax VARCHAR2(30),
    Email VARCHAR2(50) UNIQUE,
    Contact VARCHAR2(30) NOT NULL,
    UNIQUE (StoreName, City)
    );

    CREATE TABLE PURCHASE_ITEM
    (
    PurchaseItemID INT PRIMARY KEY,
    StoreID INT NOT NULL REFERENCES STORE(StoreID) ON DELETE CASCADE ON UPDATE CASCADE,
    "Date" DATE NOT NULL,
    Description VARCHAR2(30) NOT NULL,
    Category VARCHAR2(30),
    PriceUsed NUMBER(15, 2)
    );

    CREATE SEQUENCE pur_seq
    START WITH 500 
    INCREMENT BY 5;

    CREATE OR REPLACE TRIGGER Purchase
    BEFORE INSERT ON PURCHASE_ITEM
    FOR EACH ROW
    BEGIN
    SELECT pur_seq.NEXTVAL
    INTO :new.PurchaseItemID
    FROM dual;
    END;

    CREATE TABLE SHIPPER
    (
    ShipperID INT PRIMARY KEY,
    ShipperName VARCHAR2(30) NOT NULL,
    Phone VARCHAR2(30) NOT NULL,
    Fax VARCHAR2(30),
    Email VARCHAR2(50) UNIQUE,
    Contact VARCHAR2(30) NOT NULL
    );

    CREATE TABLE SHIPMENT
    (
    ShipmentID INT PRIMARY KEY Auto Increment,
    ShipperID INT NOT NULL REFERENCES SHIPPER(ShipperID) ON DELETE CASCADE ON UPDATE CASCADE,
    ShipperInvoiceNumber INT NOT NULL UNIQUE,
    Origin VARCHAR2(30) NOT NULL,
    Destination VARCHAR2(30) NOT NULL,
    DepartureDate DATE,
    ArrivalDate DATE
    );

    ALTER TABLE SHIPMENT AUTO_INCREMENT = 100;

    CREATE TABLE SHIPMENT_ITEM
    (
    ShipmentID INT NOT NULL REFERENCES SHIPMENT(ShipmentID) ON DELETE CASCADE ON UPDATE CASCADE,
    ShipmentItemID INT NOT NULL,
    PurchaseItemID INT NOT NULL REFERENCES PURCHASE_ITEM(PurchaseItemID) ON DELETE CASCADE ON UPDATE CASCADE,
    InsuredValue NUMBER(15, 2) NOT NULL defaut 100,
    PRIMARY KEY (ShipmentID, ShipmentItemID)
    );

В итоге обрабатывается только 4 оператора, и я получаю следующие сообщения об ошибках:

    CREATE TABLE STORE ( StoreID INT PRIMARY K   -   ORA-00906: missing left parenthesis
    CREATE TABLE PURCHASE_ITEM ( PurchaseItemID INT   -   ORA-00907: missing right parenthesis
    CREATE SEQUENCE pur_seq START WITH 500 INCREMENT BY 5   -   ORA-00955: name is already used by an existing object   
    CREATE OR REPLACE TRIGGER Purchase BEFORE INSERT ON PURCHASE   -   ORA-00942: table or view does not exist  

Я совершенно незнаком с Oracle 11g , Я не уверен, что я использую правильное заявление в нем для моего назначения. Я иду только по этим инструкциям:

"Для этого задания вы должны написать сценарии для создания таблиц и вставки записей. В oracle 11g я не хочу, чтобы вы использовали инструменты для генерации таблиц, Вы обязаны писать сценарии для создания таблиц и записей, и вам необходимо будет включить сценарии для представления. "

Пожалуйста, что я делаю не так?

1 Ответ

1 голос
/ 21 апреля 2020

Позвольте мне обобщить проблемы с вашими сценариями

Сначала вы должны заключить проверочное ограничение в фигурные скобки, как показано ниже

  CREATE TABLE STORE
        (
        StoreID INT PRIMARY KEY,
        StoreName VARCHAR2(30) NOT NULL,
        City VARCHAR2(30) NOT NULL,
        Country VARCHAR2(30) NOT NULL CHECK (Country in ('China','Egypt','United States','Spain','New Zealand','Mexico','Africa')),
        Phone VARCHAR2(30) NOT NULL,
        Fax VARCHAR2(30),
        Email VARCHAR2(50) UNIQUE,
        Contact VARCHAR2(30) NOT NULL,
        UNIQUE (StoreName, City)
        );

Во-вторых, в Oracle нет ON UPDATE CASCADE 11g, поэтому вам необходимо удалить его из оператора CREATE TABLE

В-третьих, в столбцах нет Auto increment в Oracle 11G. Так что SO Обходной путь

Пожалуйста, дайте мне знать с этими исправлениями, решена ли ваша проблема

...