Bases de Datos - Error al crear la base de datos

   
Vista:

Error al crear la base de datos

Publicado por Victor (1 intervención) el 16/12/2017 09:49:52
no puedo crear la base de datos no se cual es el error
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
-- 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='TRADITIONAL,ALLOW_INVALID_DATES';
 
-- -----------------------------------------------------
-- Schema ferreteria
-- -----------------------------------------------------
 
-- -----------------------------------------------------
-- Schema ferreteria
-- -----------------------------------------------------
CREATE SCHEMA IF NOT EXISTS `ferreteria` DEFAULT CHARACTER SET utf8 ;
USE `ferreteria` ;
 
-- -----------------------------------------------------
-- Table `ferreteria`.`empleado`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `ferreteria`.`empleado` (
  `rut` VARCHAR(11) NOT NULL,
  `nombre` VARCHAR(20) NOT NULL,
  `apellido` VARCHAR(20) NOT NULL,
  `telefono` INT(11) NOT NULL,
  PRIMARY KEY (`rut`))
ENGINE = InnoDB;
 
 
-- -----------------------------------------------------
-- Table `ferreteria`.`datosOrden`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `ferreteria`.`datosOrden` (
  `num_orden` INT(11) NOT NULL,
  `fecha` DATE NOT NULL,
  `rut` VARCHAR(11) NOT NULL,
  PRIMARY KEY (`num_orden`),
  INDEX `fk_datosOrden_empleado1_idx` (`rut` ASC),
  CONSTRAINT `fk_datosOrden_empleado1`
    FOREIGN KEY (`rut`)
    REFERENCES `ferreteria`.`empleado` (`rut`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;
 
 
-- -----------------------------------------------------
-- Table `ferreteria`.`orden_de_compra`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `ferreteria`.`orden_de_compra` (
  `num_orden` INT(11) NOT NULL,
  `codigo_producto` INT(11) NOT NULL,
  `cantidad` INT(11) NOT NULL,
  PRIMARY KEY (`num_orden`, `codigo_producto`),
  CONSTRAINT `fk_orden_de_compra_datosOrden1`
    FOREIGN KEY (`num_orden`)
    REFERENCES `ferreteria`.`datosOrden` (`num_orden`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;
 
 
-- -----------------------------------------------------
-- Table `ferreteria`.`factura`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `ferreteria`.`factura` (
  `num_factura` INT(11) NOT NULL,
  `codigo_producto` INT(11) NOT NULL,
  `valor_total` INT(11) NOT NULL,
  `cantidad` INT(11) NOT NULL,
  PRIMARY KEY (`num_factura`, `codigo_producto`))
ENGINE = InnoDB;
 
 
-- -----------------------------------------------------
-- Table `ferreteria`.`proveedor`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `ferreteria`.`proveedor` (
  `codigo_proveedor` INT(11) NOT NULL,
  `nombre` VARCHAR(20) NOT NULL,
  `direccion` VARCHAR(50) NOT NULL,
  PRIMARY KEY (`codigo_proveedor`))
ENGINE = InnoDB;
 
 
-- -----------------------------------------------------
-- Table `ferreteria`.`infoFactura`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `ferreteria`.`infoFactura` (
  `num_factura` INT(11) NOT NULL,
  `fecha` DATE NOT NULL,
  `codigo_proveedor` INT(11) NOT NULL,
  `rut` VARCHAR(11) NOT NULL,
  PRIMARY KEY (`num_factura`),
  INDEX `fk_infoFactura_proveedor1_idx` (`codigo_proveedor` ASC),
  INDEX `fk_infoFactura_empleado1_idx` (`rut` ASC),
  CONSTRAINT `fk_infoFactura_proveedor1`
    FOREIGN KEY (`codigo_proveedor`)
    REFERENCES `ferreteria`.`proveedor` (`codigo_proveedor`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_infoFactura_empleado1`
    FOREIGN KEY (`rut`)
    REFERENCES `ferreteria`.`empleado` (`rut`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_infoFactura_factura1`
    FOREIGN KEY (`num_factura`)
    REFERENCES `ferreteria`.`factura` (`num_factura`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;
 
 
-- -----------------------------------------------------
-- Table `ferreteria`.`stock`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `ferreteria`.`stock` (
  `codigo_producto` INT(11) NOT NULL,
  `nombre` VARCHAR(20) NOT NULL,
  `valor` INT(11) NOT NULL,
  `stock_disponible` INT(11) NOT NULL,
  `stock_alerta` INT(11) NOT NULL,
  PRIMARY KEY (`codigo_producto`),
  CONSTRAINT `fk_stock_orden_de_compra1`
    FOREIGN KEY (`codigo_producto`)
    REFERENCES `ferreteria`.`orden_de_compra` (`codigo_producto`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_stock_factura1`
    FOREIGN KEY (`codigo_producto`)
    REFERENCES `ferreteria`.`factura` (`codigo_producto`)
    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;
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder
Imágen de perfil de xve

Error al crear la base de datos

Publicado por xve (107 intervenciones) el 17/12/2017 10:35:01
Hola Victor, esta linea creo que esta mal...
REFERENCES `ferreteria`.`orden_de_compra` (`codigo_producto`)

No existe el campo codigo_producto en la tabla orden_de_compra!!
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar
Revisar política de publicidad