elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.


Tema destacado: Como proteger una cartera - billetera de Bitcoin


+  Foro de elhacker.net
|-+  Programación
| |-+  Desarrollo Web
| | |-+  Bases de Datos (Moderador: Carloswaldo)
| | | |-+  necesito opinión e ideas sobre mi base de datos
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: 1 [2] Ir Abajo Respuesta Imprimir
Autor Tema: necesito opinión e ideas sobre mi base de datos  (Leído 11,524 veces)
N4X

Desconectado Desconectado

Mensajes: 74



Ver Perfil WWW
Re: necesito opinión e ideas sobre mi base de datos
« Respuesta #10 en: 13 Enero 2010, 10:32 am »

a lo que te refieres es a tener una sola tabla tipo:

tabla_oracion_sitios

id_pais id_ca id_provincia id_comarca id_ciudad nombre

y si quiero poner españa:

id_pais id_ca id_provincia id_comarca id_ciudad nombre
    1        0         0                  0                   0        españa

agrego una comunidad autonoma
id_pais id_ca id_provincia id_comarca id_ciudad nombre
    1        1        0                   0              0           cataluña

así? hmmm si es el caso... podria ser una buena idea... y trabajar del mismo modo los top... hmmmmm pensaré en ello..

un ejemplo de top10 podria ser:

tabla_oracion_top10

id_pais id_ca id_provincia id_comarca id_ciudad id_peticion posicion
   1         1           0                 0             0              5             1
con lo cual marcariamos la petición (o circular) 5 en la primera posición de cataluña (siguiendo los 2 ejemplos anteriores)

hmm me gusta bastante... lo pensaré bien a lo largo del día, pero quiza sea la mejor solución


la comarca no es otra cosa que dividir en porciones mas pequeñas un territorio (http://es.wikipedia.org/wiki/Comarca)

si ponemos un ejemplo seria:

pais: españa
comunidad autonoma: cataluña
provincia: tarragona
comarca: baix camp
ciudad: reus
(http://es.wikipedia.org/wiki/Reus)

lo que yo digo es que hay un representante para cada ciudad, uno para cada comarca, uno para cada provincia, etc...

el de ciudad envia su top10 al de su comarca el cual recive todos los top10 de las ciudades que componen la comarca y así sucesivamente hasta llegar al pais.


AGREGO:

impresionante como cambia la cosa... (me e pasado a las herramientas de mysql por mayor comodidad xD)

ahora si está mas bonita esta parte, a mi parecer ni punto de comparación  ;-)

link: http://img11.imageshack.us/img11/1998/dibujoiyo.jpg

muchas gracias por todo...

iré haciendo las demás y si tengo problemas agrego :)


un problemita es a la hora de importar el código SQL del Workbench a MySQL

le doy a sincronizar y me dice que hay un error, pero no donde ni cual es...

Código
  1. Executing SQL script IN server
  2.  
  3. ERROR: Error 1005: Can't create table 'smf_test.web_oracion' (errno: 150)
  4.  
  5.  
  6.  
  7.  
  8.  
  9. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion` (
  10.  
  11.  `id_peticion` INT(10) UNSIGNED NOT NULL ,
  12.  
  13.  `peticion` VARCHAR(250) NOT NULL ,
  14.  
  15.  `usr_rel` MEDIUMINT(2) UNSIGNED NOT NULL DEFAULT 1 ,
  16.  
  17.  `votos` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  18.  
  19.  `hora` TIMESTAMP NOT NULL ,
  20.  
  21.  `autor` MEDIUMINT(8) UNSIGNED NOT NULL ,
  22.  
  23.  `id_pais` INT(10) UNSIGNED NOT NULL ,
  24.  
  25.  `id_ca` INT(10) UNSIGNED NOT NULL ,
  26.  
  27.  `id_provincia` INT(10) UNSIGNED NOT NULL ,
  28.  
  29.  `id_comarca` INT(10) UNSIGNED NOT NULL ,
  30.  
  31.  `id_ciudad` INT(10) UNSIGNED NOT NULL ,
  32.  
  33.  `id_cat` INT(10) UNSIGNED NOT NULL ,
  34.  
  35.  PRIMARY KEY (`id_peticion`) ,
  36.  
  37.  INDEX `relacion2` (`id_comarca` ASC, `id_ciudad` ASC, `id_provincia` ASC, `id_ca` ASC, `id_pais` ASC) ,
  38.  
  39.  INDEX `categoria` (`id_cat` ASC) ,
  40.  
  41.  CONSTRAINT `relacion2`
  42.  
  43.    FOREIGN KEY (`id_comarca` , `id_ciudad` , `id_provincia` , `id_ca` , `id_pais` )
  44.  
  45.    REFERENCES `smf_test`.`web_oracion_lugares` (`id_comarca` , `id_ciudad` , `id_provincia` , `id_ca` , `id_pais` )
  46.  
  47.    ON DELETE NO ACTION
  48.  
  49.    ON UPDATE CASCADE,
  50.  
  51.  CONSTRAINT `categoria`
  52.  
  53.    FOREIGN KEY (`id_cat` )
  54.  
  55.    REFERENCES `smf_test`.`web_oracion_cat` (`id_cat` )
  56.  
  57.    ON DELETE CASCADE
  58.  
  59.    ON UPDATE CASCADE)
  60.  
  61. ENGINE = InnoDB
  62.  
  63. DEFAULT CHARACTER SET = utf8
  64.  
  65. COLLATE = utf8_general_ci
  66.  
  67.  
  68.  
  69. SQL script execution finished: statements: 10 succeeded, 1 failed
  70.  


el sql de phpmy admin dice:

#1005 - Can't create table 'smf_test.web_oracion' (errno: 150)


saludos
nax



« Última modificación: 13 Enero 2010, 23:42 pm por N4X » En línea

^Tifa^


Desconectado Desconectado

Mensajes: 2.804


Ver Perfil
Re: necesito opinión e ideas sobre mi base de datos
« Respuesta #11 en: 14 Enero 2010, 15:27 pm »

Vaya que cambio de modelo de tablas  ;-)  me gusta como se ve. Y me alegra que te movieses para WorkBench de MySQL  ;D

Cuando he visto el error 1005 (errno) no habia leido el script SQL y ya sabia de antemano que eran tablas InnoDB y habia una o mas Foreign Keys dentro  :xD es que es tan comun este error con las referencias foreign key en InnoDB...(Aun no se porque) pero ocurre por variadas razones algunas hasta sin sentido.

ya pegaste la estructura logica de la tabla web_oracion que viene siendo el hijo, necesito la estructura logica de las tablas padres web_oracion_lugares y web_oracion_cat ya que las razones del fallo anterior son bastantes variadas (No hay 1 sola definicion para que se de el fallo 1005) aveces ocurre porque una tabla hijo no puede hacer un FK a otro FK de otra tabla hijo, aveces me ha pasado porque 1 campo FK INTEGER debia declararlo como UNSIGNED, entre otras situaciones....

Pero necesito la estructura logica de las otras 2 tablas, no solo de la que pegaste aca, para depurar y ver como se podria resolver.

Un Saludo.


En línea

N4X

Desconectado Desconectado

Mensajes: 74



Ver Perfil WWW
Re: necesito opinión e ideas sobre mi base de datos
« Respuesta #12 en: 14 Enero 2010, 16:08 pm »

ok ahora te lo doy...

me e dado cuenta que el error no es solo uno..

por haí decian que habia que cambiar los nombres de las FK porque ya existian.. (nothing)

que las FK sean exactamente igual a la original (creo que ya lo son... pero nada)

este es el sql que genera al sincronizar con la bd.
el mydb no e encontrado aun donde borrarlo y que no vuelva  :laugh:

Código
  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 `mydb` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci ;
  6.  
  7. USE `mydb`;
  8.  
  9. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion_cat` (
  10.  `id_cat` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT ,
  11.  `categoria` VARCHAR(100) NOT NULL DEFAULT 0 ,
  12.  PRIMARY KEY (`id_cat`) )
  13. ENGINE = InnoDB
  14. AUTO_INCREMENT = 3
  15. DEFAULT CHARACTER SET = utf8
  16. COLLATE = utf8_general_ci;
  17.  
  18. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion_lugares` (
  19.  `id_pais` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  20.  `id_ca` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  21.  `id_provincia` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  22.  `id_comarca` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  23.  `id_ciudad` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  24.  `nombre` VARCHAR(100) NOT NULL DEFAULT 0 ,
  25.  `responsable` MEDIUMINT(8) UNSIGNED NOT NULL DEFAULT 0 ,
  26.  PRIMARY KEY (`id_pais`, `id_ca`, `id_provincia`, `id_comarca`, `id_ciudad`) )
  27. ENGINE = InnoDB
  28. DEFAULT CHARACTER SET = utf8
  29. COLLATE = utf8_general_ci;
  30.  
  31. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion_top10` (
  32.  `id_top` INT(10) UNSIGNED NOT NULL ,
  33.  `id_pais1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  34.  `id_ca1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  35.  `id_provincia1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  36.  `id_comarca1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  37.  `id_ciudad1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  38.  `id_peticion1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  39.  `posicion` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  40.  PRIMARY KEY (`id_top`) ,
  41.  INDEX `relacion1` (`id_pais1` ASC, `id_ca1` ASC, `id_provincia1` ASC, `id_comarca1` ASC, `id_ciudad1` ASC) ,
  42.  INDEX `peticion` (`id_peticion1` ASC) ,
  43.  CONSTRAINT `relacion1`
  44.    FOREIGN KEY (`id_pais1` , `id_ca1` , `id_provincia1` , `id_comarca1` , `id_ciudad1` )
  45.    REFERENCES `smf_test`.`web_oracion_lugares` (`id_pais` , `id_ca` , `id_provincia` , `id_comarca` , `id_ciudad` )
  46.    ON DELETE NO ACTION
  47.    ON UPDATE CASCADE,
  48.  CONSTRAINT `peticion`
  49.    FOREIGN KEY (`id_peticion1` )
  50.    REFERENCES `smf_test`.`web_oracion` (`id_peticion` )
  51.    ON DELETE CASCADE
  52.    ON UPDATE CASCADE)
  53. ENGINE = InnoDB
  54. DEFAULT CHARACTER SET = utf8
  55. COLLATE = utf8_general_ci;
  56.  
  57. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion` (
  58.  `id_peticion` INT(10) UNSIGNED NOT NULL ,
  59.  `peticion` VARCHAR(250) NOT NULL DEFAULT 0 ,
  60.  `usr_rel` MEDIUMINT(2) UNSIGNED NOT NULL DEFAULT 1 ,
  61.  `votos` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  62.  `hora` TIMESTAMP NOT NULL ,
  63.  `autor` MEDIUMINT(8) UNSIGNED NOT NULL DEFAULT 0 ,
  64.  `id_pais2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  65.  `id_ca2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  66.  `id_provincia2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  67.  `id_comarca2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  68.  `id_ciudad2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  69.  `id_cat2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  70.  PRIMARY KEY (`id_peticion`) ,
  71.  INDEX `relacion2` (`id_comarca2` ASC, `id_ciudad2` ASC, `id_provincia2` ASC, `id_ca2` ASC, `id_pais2` ASC) ,
  72.  INDEX `categoria` (`id_cat2` ASC) ,
  73.  CONSTRAINT `relacion2`
  74.    FOREIGN KEY (`id_comarca2` , `id_ciudad2` , `id_provincia2` , `id_ca2` , `id_pais2` )
  75.    REFERENCES `smf_test`.`web_oracion_lugares` (`id_comarca` , `id_ciudad` , `id_provincia` , `id_ca` , `id_pais` )
  76.    ON DELETE NO ACTION
  77.    ON UPDATE CASCADE,
  78.  CONSTRAINT `categoria`
  79.    FOREIGN KEY (`id_cat2` )
  80.    REFERENCES `smf_test`.`web_oracion_cat` (`id_cat` )
  81.    ON DELETE CASCADE
  82.    ON UPDATE CASCADE)
  83. ENGINE = InnoDB
  84. DEFAULT CHARACTER SET = utf8
  85. COLLATE = utf8_general_ci;
  86.  
  87.  
  88. SET SQL_MODE=@OLD_SQL_MODE;
  89. SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
  90. SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
  91.  

al principio pensaba que era la tabla top10, pues esa se generaba bien y la principal (web_oracion), pero e borrado toda la bd y en sincronizado sin el top10 y da el mismo error.

muchas gracias por el soporte :)
a estas alturas andaria desesperado XD
En línea

^Tifa^


Desconectado Desconectado

Mensajes: 2.804


Ver Perfil
Re: necesito opinión e ideas sobre mi base de datos
« Respuesta #13 en: 14 Enero 2010, 18:17 pm »

Me gustaria decirte cual era el problema..... pero creo que si vez el Codigo modificado te daras cuenta...


Codigo:

Código
  1.  
  2. SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
  3. SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
  4. SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL';
  5.  
  6. CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci ;
  7.  
  8. USE `mydb`;
  9.  
  10. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion_cat` (
  11.  `id_cat` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT ,
  12.  `categoria` VARCHAR(100) NOT NULL DEFAULT 0 ,
  13.  PRIMARY KEY (`id_cat`) )
  14. ENGINE = InnoDB
  15. AUTO_INCREMENT = 3
  16. DEFAULT CHARACTER SET = utf8
  17. COLLATE = utf8_general_ci;
  18.  
  19. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion_lugares` (
  20.  `id_pais` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  21.  `id_ca` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  22.  `id_provincia` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  23.  `id_comarca` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  24.  `id_ciudad` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  25.  `nombre` VARCHAR(100) NOT NULL DEFAULT 0 ,
  26.  `responsable` MEDIUMINT(8) UNSIGNED NOT NULL DEFAULT 0 ,
  27.  PRIMARY KEY (`id_pais`, `id_ca`, `id_provincia`, `id_comarca`, `id_ciudad`) )
  28. ENGINE = InnoDB
  29. DEFAULT CHARACTER SET = utf8
  30. COLLATE = utf8_general_ci;
  31.  
  32. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion` (
  33.  `id_peticion` INT(10) UNSIGNED NOT NULL ,
  34.  `peticion` VARCHAR(250) NOT NULL DEFAULT 0 ,
  35.  `usr_rel` MEDIUMINT(2) UNSIGNED NOT NULL DEFAULT 1 ,
  36.  `votos` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  37.  `hora` TIMESTAMP NOT NULL ,
  38.  `autor` MEDIUMINT(8) UNSIGNED NOT NULL DEFAULT 0 ,
  39.  `id_pais2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  40.  `id_ca2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  41.  `id_provincia2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  42.  `id_comarca2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  43.  `id_ciudad2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  44.  `id_cat2` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  45.  PRIMARY KEY (`id_peticion`) ,
  46.  INDEX `relacion2` (`id_pais2` ASC, `id_ca2` ASC, `id_provincia2` ASC, `id_comarca2` ASC, `id_ciudad2` ASC) ,
  47.  INDEX `categoria` (`id_cat2` ASC) ,
  48.  /*CONSTRAINT `relacion2`*/
  49.    FOREIGN KEY (`id_pais2`, `id_ca2` , `id_provincia2` , `id_comarca2`,  `id_ciudad2` )
  50.    REFERENCES `smf_test`.`web_oracion_lugares` (`id_pais`, `id_ca` , `id_provincia` , `id_comarca` , `id_ciudad` )
  51.    ON DELETE NO ACTION
  52.    ON UPDATE CASCADE,
  53.  CONSTRAINT `categoria`
  54.    FOREIGN KEY (`id_cat2` )
  55.    REFERENCES `smf_test`.`web_oracion_cat` (`id_cat` )
  56.    ON DELETE CASCADE
  57.    ON UPDATE CASCADE)
  58. ENGINE = InnoDB
  59. DEFAULT CHARACTER SET = utf8
  60. COLLATE = utf8_general_ci;
  61.  
  62.  
  63. CREATE  TABLE IF NOT EXISTS `smf_test`.`web_oracion_top10` (
  64.  `id_top` INT(10) UNSIGNED NOT NULL ,
  65.  `id_pais1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  66.  `id_ca1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  67.  `id_provincia1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  68.  `id_comarca1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  69.  `id_ciudad1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  70.  `id_peticion1` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  71.  `posicion` INT(10) UNSIGNED NOT NULL DEFAULT 0 ,
  72.  PRIMARY KEY (`id_top`) ,
  73.  INDEX `relacion1` (`id_pais1` ASC, `id_ca1` ASC, `id_provincia1` ASC, `id_comarca1` ASC, `id_ciudad1` ASC) ,
  74.  INDEX `peticion` (`id_peticion1` ASC) ,
  75.  CONSTRAINT `relacion1`
  76.    FOREIGN KEY (`id_pais1` , `id_ca1` , `id_provincia1` , `id_comarca1` , `id_ciudad1` )
  77.    REFERENCES `smf_test`.`web_oracion_lugares` (`id_pais` , `id_ca` , `id_provincia` , `id_comarca` , `id_ciudad` )
  78.    ON DELETE NO ACTION
  79.    ON UPDATE CASCADE,
  80. CONSTRAINT `peticion`
  81.    FOREIGN KEY (`id_peticion1` )
  82.    REFERENCES `smf_test`.`web_oracion` (`id_peticion` )
  83.    ON DELETE CASCADE
  84.    ON UPDATE CASCADE)
  85. ENGINE = InnoDB
  86. DEFAULT CHARACTER SET = utf8
  87. COLLATE = utf8_general_ci;
  88.  
  89. SET SQL_MODE=@OLD_SQL_MODE;
  90. SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
  91. SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
  92.  
  93.  

Te dare una orejita  :P

Fijate en:

Tabla web_oracion_lugares

 PRIMARY KEY (`id_pais`, `id_ca`, `id_provincia`, `id_comarca`, `id_ciudad`) )


Tabla web_oracion

INDEX `relacion2` (`id_pais2` ASC, `id_ca2` ASC, `id_provincia2` ASC, `id_comarca2` ASC, `id_ciudad2` ASC) ,
  INDEX `categoria` (`id_cat2` ASC) ,
  /*CONSTRAINT `relacion2`*/
    FOREIGN KEY (`id_pais2`, `id_ca2` , `id_provincia2` , `id_comarca2`,  `id_ciudad2` )
    REFERENCES `smf_test`.`web_oracion_lugares` (`id_pais`, `id_ca` , `id_provincia` , `id_comarca` , `id_ciudad` )


Observate el orden de campos PRIMARY KEY de web_oracion_lugares y el orden modificado actual de los INDICES y FK de web_oracion

Un error tonto lo se....... pero ya vez como trabaja InnoDB en MySQL aveces.

Prueba el code ahora  ;)
En línea

N4X

Desconectado Desconectado

Mensajes: 74



Ver Perfil WWW
Re: necesito opinión e ideas sobre mi base de datos
« Respuesta #14 en: 14 Enero 2010, 19:35 pm »

ja... si que es para darse un par de palmaditas.........  :-X

muchas gracias xD no sabia yo que hacia esa distincción de orden...

enfin... pues bueno... ya como no podia ser distinto... dejo otro "problema" (al final me vas a cobrar xD)

ejecuto el sql.. todo correcto

me voy al phpmyadmin y en la parte de diseñador, no se ve las relaciones hacia web_oracion_lugares... bueno como normalmente la parte Diseñador siempre me ha funcionado como ha querido... me voy a las tablas y busco las FK... estan alli (en ambas tablas)

entonces... creo unos cuantos datos... me relaciona todo bien, es decir cuando voy a guardar datos en web_oracion, en id_cat2 (que va relacionado con las categorias) me muestra una lista de todas ellas... sin problemas

pero en la parte de id_pais2, etc... no me muestra ninguna lista y al guardar los datos no me muestra un "link" como suele hacer....

hay alguna forma de comprobar que realmente están funcionando correctamente?

saludos!
nax
En línea

^Tifa^


Desconectado Desconectado

Mensajes: 2.804


Ver Perfil
Re: necesito opinión e ideas sobre mi base de datos
« Respuesta #15 en: 14 Enero 2010, 19:41 pm »

Citar
ja... si que es para darse un par de palmaditas.........  :-X

muchas gracias xD no sabia yo que hacia esa distincción de orden...

Tranquilo, yo tampoco lo sabia lol  :xD  me di cuenta depurando el Codigo en MySQL. Pero yo tampoco sabia que InnoDB exhigia este orden de PK con FK.

Citar
hay alguna forma de comprobar que realmente están funcionando correctamente?

Si ya de antemano se actualizan las tablas padre-hijo es porque esta funcionando. Si las relaciones existen realmente (Y podras darte cuenta con SHOW CREATE TABLE tabla) y vez algun punto donde diga REFERENCES es porque efectivamente la relacion existe. Ahora, todo se va a regir acorde a las condiciones que tu diste en este caso:

    ON DELETE NO ACTION
    ON UPDATE CASCADE

Por lo que estaras consciente que si eliminas aca en el padre no se aplicara en el hijo, pero si actualizas en el padre por ley debe actualizarse en el hijo, sino pasa asi es porque las tablas no estan en motor InnoDB o porque el nivel de aislamiento no es el que trae por defecto MySQL (Este ultimo lo dudo que lo hayas modificado)

Actualiza un dato padre y verifica si se aplica al hijo  ;)
En línea

N4X

Desconectado Desconectado

Mensajes: 74



Ver Perfil WWW
Re: necesito opinión e ideas sobre mi base de datos
« Respuesta #16 en: 14 Enero 2010, 19:47 pm »

Si ya de antemano se actualizan las tablas padre-hijo es porque esta funcionando.

que gran verdad!! que espeso estoy hoy  :P

ok todo correcto hasta día de hoy, cualquier cosa edito  :silbar:
En línea

Páginas: 1 [2] Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Necesito muchas ideas sobre los usos de punteros y clases.
Programación C/C++
anonimo12121 2 2,171 Último mensaje 5 Marzo 2011, 20:03 pm
por anonimo12121
Necesito estresar una base de datos al punto de corromperla
Hacking
Bud4 2 4,070 Último mensaje 1 Marzo 2012, 22:43 pm
por tragantras
Opinion sobre estructura de datos
Dudas Generales
cefagure 6 4,952 Último mensaje 11 Julio 2015, 15:17 pm
por MinusFour
sobre base datos
Dudas Generales
Raulhispano 1 1,965 Último mensaje 4 Enero 2020, 01:44 am
por ivancea96
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines