Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] PHP OO Union dos tablas y mostrar resultados en tabla

Estas en el tema de Union dos tablas y mostrar resultados en tabla en el foro de PHP en Foros del Web. Buenas tengo dos tablas unidas entre ellas por un id las cuales necesito mostrar en una tabla todos los campos de las mismas pero solo ...
  #1 (permalink)  
Antiguo 18/06/2015, 12:36
 
Fecha de Ingreso: junio-2015
Mensajes: 9
Antigüedad: 8 años, 10 meses
Puntos: 0
Union dos tablas y mostrar resultados en tabla

Buenas tengo dos tablas unidas entre ellas por un id las cuales necesito mostrar en una tabla todos los campos de las mismas pero solo consigo mostrar una de las dos...

Este es mi código mostrando 1 de ellas, y que funciona:
Código PHP:
<?php
session_start
();
include_once 
"includes/conexionDB.php";
$link db_connect();
//$sql = "select * from clientes where usuario = '".$userid."'";
$sql "select * from clientes ";

$rs mysql_query($sql,$link);

?>
<body>
<h4>Listado de Clientes</h4>
<br>
<?php 
echo "<table>";  
echo 
"<tr>";  
echo 
"<th>Id</th>";  
echo 
"<th>Nombre</th>";  
echo 
"<th>Apellido</th>";  
echo 
"<th>E-mail</th>";  
echo 
"<th>Empresa</th>";  
echo 
"<th>Editar</th>";  
echo 
"<th>Eliminar</th>";  
echo 
"</tr>";  
while (
$row mysql_fetch_row($rs)){   
    echo 
"<tr>";  
echo 
"<td>$row[0]</td>";     
echo 
"<td>$row[2]</td>";  
echo 
"<td>$row[3]</td>";  
echo 
"<td>$row[4]</td>"
echo 
"</tr>";  
}  
echo 
"</table>";  
?>  
</body>
he probado a hacer joins pero algo hago mal, de todos modos no estoy muy seguro como recuperar los datos de la otra tabla..

la otra tabla (empresa) solo tiene dos campos... ID y Nombre
  #2 (permalink)  
Antiguo 18/06/2015, 12:42
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Union dos tablas y mostrar resultados en tabla

Cita:
he probado a hacer joins pero algo hago mal, de todos modos no estoy muy seguro como recuperar los datos de la otra tabla..
¿Y no crees que primero debes resolver tu problema de SQL entonces?

Con código PHP no corriges una consulta de SQL.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 18/06/2015, 12:53
 
Fecha de Ingreso: junio-2015
Mensajes: 9
Antigüedad: 8 años, 10 meses
Puntos: 0
Respuesta: Union dos tablas y mostrar resultados en tabla

Cita:
Iniciado por pateketrueke Ver Mensaje
¿Y no crees que primero debes resolver tu problema de SQL entonces?

Con código PHP no corriges una consulta de SQL.
tal vez me expresé mal, mostrar los datos haciendo un inner join no me los muestra pero es porque no sé como recuperarlo luego en el php, por eso muestro los datos que si funcionan
  #4 (permalink)  
Antiguo 19/06/2015, 01:01
 
Fecha de Ingreso: junio-2015
Mensajes: 9
Antigüedad: 8 años, 10 meses
Puntos: 0
Respuesta: Union dos tablas y mostrar resultados en tabla

ya lo he solucionado, el problema, era la query

Código PHP:
$sql "SELECT c.id AS idcli, c.Nombre as nomcli,c.Apellidos as appcli, c.email as email, e.Nombre as nomemp FROM clientes c, empresas e WHERE c.IdEmp=e.Id"
y el código quedaría así:

Código PHP:
<?php
session_start
();
include_once 
"includes/conexionDB.php";
$link db_connect();
//$sql = "select * from clientes";
//$sql = "select clientes.Id, clientes.Nombre, clientes.Apellidos, clientes.Email, empresas.Nombre from clientes INNER JOIN clientes on clientes.Id = empresas.IdEmp";
$sql "SELECT c.id AS idcli, c.Nombre as nomcli,c.Apellidos as appcli, c.email as email, e.Nombre as nomemp FROM clientes c, empresas e WHERE c.IdEmp=e.Id";
$rs mysql_query($sql,$link);

?>
<body>
<h4>Listado de Clientes</h4>
<br>
<?php 
echo "<table>";  
echo 
"<tr>";  
echo 
"<th>Id</th>";  
echo 
"<th>Nombre</th>";  
echo 
"<th>Apellido</th>";  
echo 
"<th>E-mail</th>";  
echo 
"<th>Empresa</th>";  
echo 
"<th>Editar</th>";  
echo 
"<th>Eliminar</th>";  
echo 
"</tr>";  
while (
$row mysql_fetch_row($rs)){   
    echo 
"<tr>";  
echo 
"<td>$row[0]</td>";     
echo 
"<td>$row[1]</td>";  
echo 
"<td>$row[2]</td>";  
echo 
"<td>$row[3]</td>"
echo 
"<td>$row[4]</td>"
echo 
"</tr>";  
}  
echo 
"</table>";  
?>  
</body>

Etiquetas: mysql, resultados, select, sql, tabla, tablas, union
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 10:15.