-- MySQL Script generated by MySQL Workbench -- Thu Apr 23 15:12:49 2020 -- Model: New Model Version: 1.0 -- MySQL Workbench Forward Engineering SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0; SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0; SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'; -- ----------------------------------------------------- -- Schema ristoranti_expo -- ----------------------------------------------------- -- ----------------------------------------------------- -- Schema ristoranti_expo -- ----------------------------------------------------- CREATE SCHEMA IF NOT EXISTS `ristoranti_expo` DEFAULT CHARACTER SET utf8 ; USE `ristoranti_expo` ; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Comune` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Comune` ( `Codice` INT NOT NULL, `Nome` VARCHAR(45) NOT NULL, `Provincia` VARCHAR(45) NOT NULL, PRIMARY KEY (`Codice`)) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Ristorante` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Ristorante` ( `Codice` INT NOT NULL, `Nome` VARCHAR(45) NOT NULL, `Indirizzo` VARCHAR(45) NOT NULL, `Comune` INT NOT NULL, `Etnia` VARCHAR(45) NULL, PRIMARY KEY (`Codice`), INDEX `comune_key_idx` (`Comune` ASC) VISIBLE, CONSTRAINT `comune_key` FOREIGN KEY (`Comune`) REFERENCES `ristoranti_expo`.`Comune` (`Codice`) ON DELETE NO ACTION ON UPDATE CASCADE) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Proprietario` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Proprietario` ( `Codice_Fiscale` VARCHAR(16) NOT NULL, `Nome` VARCHAR(45) NOT NULL, `Cognome` VARCHAR(45) NOT NULL, `Data_di_Nascita` DATETIME NOT NULL, `Regione` VARCHAR(45) NULL, `Stato` VARCHAR(45) NULL, PRIMARY KEY (`Codice_Fiscale`)) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Quota_Proprieta` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Quota_Proprieta` ( `Codice_Ristorante` INT NOT NULL, `Codice_Fiscale_Proprietario` VARCHAR(16) NOT NULL, `Quota` TINYINT NOT NULL, INDEX `Risto_key_idx` (`Codice_Ristorante` ASC) VISIBLE, PRIMARY KEY (`Codice_Ristorante`, `Codice_Fiscale_Proprietario`), INDEX `fk_Quota_Proprieta_Proprietario1_idx` (`Codice_Fiscale_Proprietario` ASC) VISIBLE, CONSTRAINT `Risto_key` FOREIGN KEY (`Codice_Ristorante`) REFERENCES `ristoranti_expo`.`Ristorante` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `fk_Quota_Proprieta_Proprietario1` FOREIGN KEY (`Codice_Fiscale_Proprietario`) REFERENCES `ristoranti_expo`.`Proprietario` (`Codice_Fiscale`) ON DELETE NO ACTION ON UPDATE NO ACTION) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Ingrediente` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Ingrediente` ( `Codice` INT NOT NULL, `Nome` VARCHAR(45) NOT NULL, PRIMARY KEY (`Codice`)) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Patologia` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Patologia` ( `Codice` INT NOT NULL, `Nome` VARCHAR(45) NOT NULL, `Stima_popolazione` INT NOT NULL, PRIMARY KEY (`Codice`)) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Intolleranza` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Intolleranza` ( `Codice_Ingrediente` INT NOT NULL, `Codice_Patologia` INT NOT NULL, INDEX `Pat_key_idx` (`Codice_Patologia` ASC) VISIBLE, INDEX `Ingr_key_idx` (`Codice_Ingrediente` ASC) VISIBLE, PRIMARY KEY (`Codice_Patologia`, `Codice_Ingrediente`), CONSTRAINT `Ingr_key` FOREIGN KEY (`Codice_Ingrediente`) REFERENCES `ristoranti_expo`.`Ingrediente` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `Pat_key` FOREIGN KEY (`Codice_Patologia`) REFERENCES `ristoranti_expo`.`Patologia` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Piatto` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Piatto` ( `Codice` INT NOT NULL, `Nome` VARCHAR(45) NOT NULL, PRIMARY KEY (`Codice`)) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Menu` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Menu` ( `Codice_Ristorante` INT NOT NULL, `Codice_Piatto` INT NOT NULL, `Costo` DECIMAL(10,2) NOT NULL, INDEX `Piatto_3_key_idx` (`Codice_Piatto` ASC) VISIBLE, INDEX `Rist_3_key_idx` (`Codice_Ristorante` ASC) VISIBLE, PRIMARY KEY (`Codice_Piatto`, `Codice_Ristorante`), CONSTRAINT `Rist_3_key` FOREIGN KEY (`Codice_Ristorante`) REFERENCES `ristoranti_expo`.`Ristorante` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `Piatto_3_key` FOREIGN KEY (`Codice_Piatto`) REFERENCES `ristoranti_expo`.`Piatto` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Composizione_piatto` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Composizione_piatto` ( `Codice_Ingrediente` INT NOT NULL, `Codice_Piatto` INT NOT NULL, `Quantita` FLOAT NOT NULL, `Unita_Misura` VARCHAR(45) NOT NULL, PRIMARY KEY (`Codice_Piatto`, `Codice_Ingrediente`), INDEX `Ingr_2_key_idx` (`Codice_Ingrediente` ASC) VISIBLE, INDEX `fk_Ingredienti_piatto_Piatto1_idx` (`Codice_Piatto` ASC) VISIBLE, CONSTRAINT `Ingr_2_key` FOREIGN KEY (`Codice_Ingrediente`) REFERENCES `ristoranti_expo`.`Ingrediente` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `fk_Ingredienti_piatto_Piatto1` FOREIGN KEY (`Codice_Piatto`) REFERENCES `ristoranti_expo`.`Piatto` (`Codice`) ON DELETE NO ACTION ON UPDATE NO ACTION) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Religione` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Religione` ( `Codice` INT NOT NULL, `Nome` VARCHAR(45) NOT NULL, `Stima_popolazione` INT NOT NULL, PRIMARY KEY (`Codice`)) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Ingrediente_non_ammesso` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Ingrediente_non_ammesso` ( `Codice_Ingrediente` INT NOT NULL, `Codice_Religione` INT NOT NULL, INDEX `Ingr_key_4_idx` (`Codice_Ingrediente` ASC) VISIBLE, INDEX `Pat_key_4_idx` (`Codice_Religione` ASC) VISIBLE, PRIMARY KEY (`Codice_Ingrediente`, `Codice_Religione`), CONSTRAINT `Ingr_key_4` FOREIGN KEY (`Codice_Ingrediente`) REFERENCES `ristoranti_expo`.`Ingrediente` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `Pat_key_4` FOREIGN KEY (`Codice_Religione`) REFERENCES `ristoranti_expo`.`Religione` (`Codice`) ON DELETE CASCADE ON UPDATE CASCADE) ENGINE = InnoDB; -- ----------------------------------------------------- -- Table `ristoranti_expo`.`Parentela` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `ristoranti_expo`.`Parentela` ( `Proprietario_1` VARCHAR(16) NOT NULL, `Proprietario_2` VARCHAR(16) NOT NULL, `Grado` VARCHAR(45) NOT NULL, PRIMARY KEY (`Proprietario_1`, `Proprietario_2`), INDEX `fk_Parentela_Proprietario2_idx` (`Proprietario_2` ASC) VISIBLE, CONSTRAINT `fk_Parentela_Proprietario1` FOREIGN KEY (`Proprietario_1`) REFERENCES `ristoranti_expo`.`Proprietario` (`Codice_Fiscale`) ON DELETE NO ACTION ON UPDATE NO ACTION, CONSTRAINT `fk_Parentela_Proprietario2` FOREIGN KEY (`Proprietario_2`) REFERENCES `ristoranti_expo`.`Proprietario` (`Codice_Fiscale`) ON DELETE NO ACTION ON UPDATE NO ACTION) ENGINE = InnoDB; SET SQL_MODE=@OLD_SQL_MODE; SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS; SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;