Hola tuvieja:
El problema que tienes es que se está realizando un producto cartesiano entre tus tablas ya que no especificas ninguna relación entre las tablas... es decir, debe existir uno o más campos que relacionen los registros de las tablas. Checa este ejemplo. Supongamos que tenemos dos tablas con los siguientes datos:
Código MySQL:
Ver original+------+-------------+
| id | descripcion |
+------+-------------+
| 1 | uno |
| 2 | dos |
| 3 | tres |
+------+-------------+
+------+-------------+
| id | descripcion |
+------+-------------+
| 1 | one |
| 2 | two |
| 3 | three |
+------+-------------+
Es claro que ambas tablas están relacionadas por el campo id, supongamos ahora que queremos obtener el id = 1 de ambas tablas... tal como lo haces tu sería así:
Código MySQL:
Ver original+------+-------------+------+-------------+
| id | descripcion | id | descripcion |
+------+-------------+------+-------------+
| 1 | uno | 1 | one |
| 1 | uno | 2 | two |
| 1 | uno | 3 | three |
+------+-------------+------+-------------+
Esto es justamente un producto cartesiano, es decir, combinar un cada elemento de la tabla1 con todos los elementos de la tabla2. Para evita esto, sólo tienes que poner las relaciones que existen entre las tablas:
Código MySQL:
Ver original+------+-------------+------+-------------+
| id | descripcion | id | descripcion |
+------+-------------+------+-------------+
| 1 | uno | 1 | one |
+------+-------------+------+-------------+
Observa que en la cláusula ON tengo esta condición
tabla1.id = tabla2.id que es la que relaciona ambas tablas.
Es preferible que utilices JOIN's en lugar del listar las tablas en el FROM separadas por comas. Evita justamente estos productos cartesianos y tiene un mejor rendimiento. aunque también funciona:
Código MySQL:
Ver original -> WHERE tabla1.id
= tabla2.id
AND tabla1.id
= 1; +------+-------------+------+-------------+
| id | descripcion | id | descripcion |
+------+-------------+------+-------------+
| 1 | uno | 1 | one |
+------+-------------+------+-------------+
Observa que en el WHERE se agrega la misma condición que en el ON. Te repito que no recomiendo que lo hagas de esta manera, el ejemplo es meramente ilustrativo.
Saludos
Leo.