forked from alessandro-renz/teste-pratico-php
-
Notifications
You must be signed in to change notification settings - Fork 0
/
desafio_ondehost.sql
119 lines (103 loc) · 4.41 KB
/
desafio_ondehost.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
-- MySQL Script generated by MySQL Workbench
-- Tue Jan 29 20:00:13 2019
-- 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 mydb
-- -----------------------------------------------------
-- -----------------------------------------------------
-- Schema mydb
-- -----------------------------------------------------
CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET utf8mb4 ;
-- -----------------------------------------------------
-- Table `mydb`.`produto`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`produto` (
`id_produto` INT NOT NULL AUTO_INCREMENT,
`nm_produto` VARCHAR(100) NOT NULL,
`preco_produto` DECIMAL(10,2) NOT NULL,
`ref_produto` VARCHAR(45) NOT NULL,
PRIMARY KEY (`id_produto`),
UNIQUE INDEX `ref_produto_UNIQUE` (`ref_produto` ASC) VISIBLE)
ENGINE = InnoDB;
-- -----------------------------------------------------
-- Table `mydb`.`fornecedor`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`fornecedor` (
`id_fornecedor` INT NOT NULL AUTO_INCREMENT,
`nm_fornecedor` VARCHAR(100) NOT NULL,
PRIMARY KEY (`id_fornecedor`))
ENGINE = InnoDB;
-- -----------------------------------------------------
-- Table `mydb`.`produto_fornecedor`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`produto_fornecedor` (
`produto_id_produto` INT NOT NULL,
`fornecedor_id_fornecedor` INT NOT NULL,
PRIMARY KEY (`produto_id_produto`, `fornecedor_id_fornecedor`),
INDEX `fk_produto_has_fornecedor_fornecedor1_idx` (`fornecedor_id_fornecedor` ASC) VISIBLE,
INDEX `fk_produto_has_fornecedor_produto_idx` (`produto_id_produto` ASC) VISIBLE,
CONSTRAINT `fk_produto_has_fornecedor_produto`
FOREIGN KEY (`produto_id_produto`)
REFERENCES `mydb`.`produto` (`id_produto`)
ON DELETE NO ACTION
ON UPDATE NO ACTION,
CONSTRAINT `fk_produto_has_fornecedor_fornecedor1`
FOREIGN KEY (`fornecedor_id_fornecedor`)
REFERENCES `mydb`.`fornecedor` (`id_fornecedor`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;
-- -----------------------------------------------------
-- Table `mydb`.`endereco`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`endereco` (
`id_endereco` INT NOT NULL AUTO_INCREMENT,
`cep` VARCHAR(10) NOT NULL,
`sg_estado` VARCHAR(2) NOT NULL,
`cidade` VARCHAR(100) NOT NULL,
`rua` VARCHAR(45) NOT NULL,
`nr_endereco` VARCHAR(45) NULL,
`compl_endereco` VARCHAR(45) NULL,
PRIMARY KEY (`id_endereco`))
ENGINE = InnoDB;
-- -----------------------------------------------------
-- Table `mydb`.`venda`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`venda` (
`id_venda` INT NOT NULL AUTO_INCREMENT,
`dt_venda` DATE NOT NULL,
`total_venda` DECIMAL(10,2) NOT NULL,
`endereco_id_endereco` INT NOT NULL,
PRIMARY KEY (`id_venda`, `endereco_id_endereco`),
INDEX `fk_venda_endereco1_idx` (`endereco_id_endereco` ASC) VISIBLE,
CONSTRAINT `fk_venda_endereco1`
FOREIGN KEY (`endereco_id_endereco`)
REFERENCES `mydb`.`endereco` (`id_endereco`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;
-- -----------------------------------------------------
-- Table `mydb`.`venda_produto`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`venda_produto` (
`venda_id_venda` INT NOT NULL,
`produto_id_produto` INT NOT NULL,
`preco_produto_atual` DECIMAL(10,2) NOT NULL,
PRIMARY KEY (`venda_id_venda`, `produto_id_produto`),
INDEX `fk_venda_has_produto_produto1_idx` (`produto_id_produto` ASC) VISIBLE,
INDEX `fk_venda_has_produto_venda1_idx` (`venda_id_venda` ASC) VISIBLE,
CONSTRAINT `fk_venda_has_produto_venda1`
FOREIGN KEY (`venda_id_venda`)
REFERENCES `mydb`.`venda` (`id_venda`)
ON DELETE NO ACTION
ON UPDATE NO ACTION,
CONSTRAINT `fk_venda_has_produto_produto1`
FOREIGN KEY (`produto_id_produto`)
REFERENCES `mydb`.`produto` (`id_produto`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;