Ver Mensaje Individual
  #2 (permalink)  
Antiguo 18/06/2010, 09:25
Avatar de gnzsoloyo
gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 17 años, 1 mes
Puntos: 2658
Respuesta: me podrian echar una mano...!!

Gracias por postear el script. Eso lo hizo más fácil.
El problema está las cláusulas ON DELETE y ON UPDATE, porque en tres tablas una de ellas decía SET NULL, lo que era imposible porque el campo usado como FK estaba declarado como NOT NULL.
Un simple problema de lógica.

Código MySQL:
Ver original
  1. SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
  2. SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
  3. SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL';
  4.  
  5. CREATE SCHEMA IF NOT EXISTS `blog` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci ;
  6.  
  7. -- -----------------------------------------------------
  8. -- Table `blog`.`categoria`
  9. -- -----------------------------------------------------
  10. CREATE  TABLE IF NOT EXISTS `blog`.`categoria` (
  11.   `id_categoria` INT NOT NULL AUTO_INCREMENT ,
  12.   `nombre` VARCHAR(45) NULL ,
  13.   `descripcion` VARCHAR(100) NULL ,
  14.   PRIMARY KEY (`id_categoria`) )
  15.  
  16.  
  17. -- -----------------------------------------------------
  18. -- Table `blog`.`sub_categoria`
  19. -- -----------------------------------------------------
  20. CREATE  TABLE IF NOT EXISTS `blog`.`sub_categoria` (
  21.   `id_sub_categoria` INT NOT NULL AUTO_INCREMENT ,
  22.   `nombre` VARCHAR(30) NOT NULL ,
  23.   `id_categoria` INT NOT NULL ,
  24.   PRIMARY KEY (`id_sub_categoria`) ,
  25.   INDEX `categoria- sub_catgoria` (`id_categoria` ASC) ,
  26.   CONSTRAINT `categoria- sub_catgoria`
  27.     FOREIGN KEY (`id_categoria` )
  28.     REFERENCES `blog`.`categoria` (`id_categoria` )
  29.  
  30.  
  31. -- -----------------------------------------------------
  32. -- Table `blog`.`publicacion`
  33. -- -----------------------------------------------------
  34. CREATE  TABLE IF NOT EXISTS `blog`.`publicacion` (
  35.   `id_publicacion` INT NOT NULL AUTO_INCREMENT ,
  36.   `titulo_publicacion` VARCHAR(100) NOT NULL ,
  37.   `texto_publicacion` TEXT NOT NULL ,
  38.   `fecha_publicacion` DATE NOT NULL ,
  39.   `id_sub_categoria` INT NOT NULL ,
  40.   PRIMARY KEY (`id_publicacion`) ,
  41.   INDEX `categoria-publicacion` (`id_sub_categoria` ASC) ,
  42.   CONSTRAINT `categoria-publicacion`
  43.     FOREIGN KEY (`id_sub_categoria` )
  44.     REFERENCES `blog`.`sub_categoria` (`id_sub_categoria` )
  45.  
  46.  
  47. -- -----------------------------------------------------
  48. -- Table `blog`.`imagen`
  49. -- -----------------------------------------------------
  50. CREATE  TABLE IF NOT EXISTS `blog`.`imagen` (
  51.   `id_imagen` INT NOT NULL AUTO_INCREMENT ,
  52.   `dir_archivo_p` VARCHAR(90) NOT NULL ,
  53.   `dir_imagen_g` VARCHAR(90) NOT NULL ,
  54.   `titulo_imagen` VARCHAR(70) NOT NULL ,
  55.   `id_publicacion` INT NOT NULL ,
  56.   PRIMARY KEY (`id_imagen`) ,
  57.   INDEX `imagen-publicacion` (`id_publicacion` ASC) ,
  58.   CONSTRAINT `imagen-publicacion`
  59.     FOREIGN KEY (`id_publicacion` )
  60.     REFERENCES `blog`.`publicacion` (`id_publicacion` )
  61.  
  62.  
  63. -- -----------------------------------------------------
  64. -- Table `blog`.`archivos_externos`
  65. -- -----------------------------------------------------
  66. CREATE  TABLE IF NOT EXISTS `blog`.`archivos_externos` (
  67.   `id_archivos_externos` INT NOT NULL AUTO_INCREMENT ,
  68.   `dir_archivo` VARCHAR(150) NOT NULL ,
  69.   `titulo` VARCHAR(80) NOT NULL ,
  70.   `tipo` INT NOT NULL ,
  71.   `id_publicacion` INT NOT NULL ,
  72.   PRIMARY KEY (`id_archivos_externos`) ,
  73.   INDEX `archivo-publicacion` (`id_publicacion` ASC) ,
  74.   CONSTRAINT `archivo-publicacion`
  75.     FOREIGN KEY (`id_publicacion` )
  76.     REFERENCES `blog`.`publicacion` (`id_publicacion` )
  77.  
  78.  
  79. -- -----------------------------------------------------
  80. -- Table `blog`.`usuario`
  81. -- -----------------------------------------------------
  82. CREATE  TABLE IF NOT EXISTS `blog`.`usuario` (
  83.   `id_usuario` INT NOT NULL AUTO_INCREMENT ,
  84.   `email` VARCHAR(70) NOT NULL ,
  85.   `clave` VARCHAR(45) NOT NULL ,
  86.   `nombre` VARCHAR(60) NULL ,
  87.   `fecha_nacimiento` VARCHAR(45) NULL ,
  88.   PRIMARY KEY (`id_usuario`) ,
  89.   UNIQUE INDEX `email_UNIQUE` (`email` ASC) )
  90.  
  91.  
  92. -- -----------------------------------------------------
  93. -- Table `blog`.`comentario`
  94. -- -----------------------------------------------------
  95. CREATE  TABLE IF NOT EXISTS `blog`.`comentario` (
  96.   `id_comentario` INT NOT NULL AUTO_INCREMENT ,
  97.   `texto_comentario` VARCHAR(255) NOT NULL ,
  98.   `fecha` DATE NOT NULL ,
  99.   `id_usuario` INT NOT NULL ,
  100.   `id_publicacion` INT NOT NULL ,
  101.   PRIMARY KEY (`id_comentario`) ,
  102.   INDEX `comentario-usuario` (`id_usuario` ASC) ,
  103.   INDEX `comentario-publicacion` (`id_publicacion` ASC) ,
  104.   CONSTRAINT `comentario-usuario`
  105.     FOREIGN KEY (`id_usuario` )
  106.     REFERENCES `blog`.`usuario` (`id_usuario` )
  107.   CONSTRAINT `comentario-publicacion`
  108.     FOREIGN KEY (`id_publicacion` )
  109.     REFERENCES `blog`.`publicacion` (`id_publicacion` )
  110.  
  111.  
  112. -- -----------------------------------------------------
  113. -- Table `blog`.`favorito`
  114. -- -----------------------------------------------------
  115. CREATE  TABLE IF NOT EXISTS `blog`.`favorito` (
  116.   `id_usuario` INT NOT NULL ,
  117.   `id_publicacion` INT NOT NULL ,
  118.   PRIMARY KEY (`id_usuario`, `id_publicacion`) ,
  119.   INDEX `usurio-favorito` (`id_usuario` ASC) ,
  120.   INDEX `favorito-publicacio` (`id_publicacion` ASC) ,
  121.   CONSTRAINT `usurio-favorito`
  122.     FOREIGN KEY (`id_usuario` )
  123.     REFERENCES `blog`.`usuario` (`id_usuario` )
  124.   CONSTRAINT `favorito-publicacio`
  125.     FOREIGN KEY (`id_publicacion` )
  126.     REFERENCES `blog`.`publicacion` (`id_publicacion` )
  127.  
  128.  
  129. -- -----------------------------------------------------
  130. -- Table `blog`.`historial`
  131. -- -----------------------------------------------------
  132. CREATE  TABLE IF NOT EXISTS `blog`.`historial` (
  133.   `id_historial` INT NOT NULL AUTO_INCREMENT ,
  134.   `id_publicacion` INT NOT NULL ,
  135.   `id_usuario` INT NOT NULL ,
  136.   `fecha_visita` DATE NOT NULL ,
  137.   PRIMARY KEY (`id_historial`) ,
  138.   INDEX `historial-publicacion` (`id_publicacion` ASC) ,
  139.   INDEX `historial-usuario` (`id_usuario` ASC) ,
  140.   CONSTRAINT `historial-publicacion`
  141.     FOREIGN KEY (`id_publicacion` )
  142.     REFERENCES `blog`.`publicacion` (`id_publicacion` )
  143.   CONSTRAINT `historial-usuario`
  144.     FOREIGN KEY (`id_usuario` )
  145.     REFERENCES `blog`.`usuario` (`id_usuario` )
  146.  
  147.  
  148. -- -----------------------------------------------------
  149. -- Table `blog`.`valoracion`
  150. -- -----------------------------------------------------
  151. CREATE  TABLE IF NOT EXISTS `blog`.`valoracion` (
  152.   `id_usuario` INT NOT NULL ,
  153.   `id_publicacion` INT NOT NULL ,
  154.   `valor_publicacion` INT NOT NULL ,
  155.   PRIMARY KEY (`id_usuario`, `id_publicacion`) ,
  156.   INDEX `usuario-valoracion` (`id_usuario` ASC) ,
  157.   INDEX `valoracion-publicacion` (`id_publicacion` ASC) ,
  158.   CONSTRAINT `usuario-valoracion`
  159.     FOREIGN KEY (`id_usuario` )
  160.     REFERENCES `blog`.`usuario` (`id_usuario` )
  161.   CONSTRAINT `valoracion-publicacion`
  162.     FOREIGN KEY (`id_publicacion` )
  163.     REFERENCES `blog`.`publicacion` (`id_publicacion` )
  164.  
  165.  
  166.  
  167. SET SQL_MODE=@OLD_SQL_MODE;
  168. SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
  169. SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)