Cita:
Iniciado por Pajaranny
Código MySQL:
Ver originalSELECT l.nombre
, p.nombre
, c.nombre
, m2
, precio, tp.nombre, telefono, calle_peatonal, id_accesibilidad, fecha
from local l
,poblacion p
, calle c
, telefono_tipo tp
La consulta me muestra 2 registros (3 veces).
He probado con distinct pero no hay manera.
Cuál es el erro?
¿Error?
Técnicamente no hay un "error", sino muy probablemente un defecto de diseño en las tablas y sus relaciones, o bien de entendimiento de lo que en Bases de Datos se llama "registro duplicado".
En Bases de Datos se denomina "registro duplicado" si y sólo si todos y cada uno de los campos entre dos registros dados repiten los valores. Si al menos una de las columnas no es igual a la otra, entonces no existe duplicidad.
¿Se entiende?
Además, debes considerar que si dos tablas dadas tienen una relación 1:N, los datos la tabla de cardinalidad 1 se repetirán en la tabla resultado N veces. Una por cada relación que exista.
Eso no es un error, es el resultado esperado.
Luego, hay que considerar que estás haciendo un JOIN implícito (la coma), que en MySQL implica que se intentará relacionar las tablas por medio de columnas que tengan el mismo nombre. Si cada tabla tiene un campo "ID", por ejemplo, pretenderá juntar los valores iguales, aunque estos no representen el mismo dato...
Ese es el error más común. Por ello se recomienda poner los campos ID con un prefijo o sufijo que identifique la tabla, y que permita a los JOIN implícitos funcionar correctamente.
Pero en ese caso es importante que aquellos campos que sean FK tengan el mismo nombre que la PK a la que se refieren.
Por ejemplo: Si "poblacion" tiene un ID, este debería llamarse algo así como poblacion_id, y la FK de "local" donde se fija la relación con "poblacion", también debe llamarse "poblacion_id". Si esto no ocurre, no se podrá usar un JOIN ,implícito y deberás recurrir al INNER JOIN explícito con su correcta sintaxis.
Por otro lado, si las tablas no tienen campos de igual nombre, se producirá lo que se denomina "producto cartesiano": MySQL intentará juntar cada registro de una tabla, con todos y cada uno de los registros de la otra, y el resultado completo, con cada uno de los registros de la tercera. Y si hay una cuarta... será lo mismo.
¿Se va entendiendo la idea?
Como mínimo tienes como error que no estás indicando la relación exacta entre las tablas que invocas, con lo que estas dejando que sea MySQL el que deba definir cómo las relaciones.
Los DBMS no adivinan las cosas semánticamente. El SQL es un lenguaje declarativo e imperativo. Sólo hará lo que le digas que haga, y sus unicas reglas de inferencia son las del SQL y los algoritmos internos que tiene, que en principio, son los que te describo antes.