Foros del Web » Programando para Internet » PHP »

proyecto php mysql varias consultas

Estas en el tema de proyecto php mysql varias consultas en el foro de PHP en Foros del Web. Buenas queria ver quien me podia ayudar en unas consultas q estoy desarrollando en php con mysql , quiero de la tabla doctores sacar los ...
  #1 (permalink)  
Antiguo 27/06/2011, 11:39
 
Fecha de Ingreso: junio-2011
Mensajes: 2
Antigüedad: 12 años, 9 meses
Puntos: 0
proyecto php mysql varias consultas

Buenas queria ver quien me podia ayudar en unas consultas q estoy desarrollando en php con mysql , quiero de la tabla doctores sacar los nombre y ordenarlos en tablas -html eso ya esta listo , pero necesito colocar al lado la especialiad aqui es donde viene mi problema no se q error estoy comentiendo en el select aqui les muestro el codigo
Código:
<?php
echo"<table border=0>";
$conexion=mysql_connect("localhost","root","") 
  or  die("Problemas en la conexion");
mysql_select_db("medicos",$conexion) 
  or  die("Problemas en la selección de la base de datos");
$registros=mysql_query("select codigo,apellido,nombre,sexo
                       from doctores order by apellido",$conexion) or
  die("Problemas en el select:".mysql_error());
  
while ($reg=mysql_fetch_array($registros))
{
	
	if($reg['sexo']=='M' or $reg['sexo']=='m'){
	echo"<tr>";
		echo "<td>"."Dr.".$reg['apellido']."&nbsp".$reg['nombre']."</td>";
		echo "</tr>";
		}
	else{
		echo"<tr>"; 
		echo "<td>"."Dra.".$reg['apellido']."&nbsp".$reg['nombre']."</td>";
		
		}
	
	
$regis=mysql_query("SELECT e.nombre_esp
  						FROM doc_esp de, especialidades e
					 WHERE de.codigo_esp = e.codigo_esp AND de.codigo_doc = ".$reg['codigo']."",$conexion) or
  die("Problemas en el select:".mysql_error());
  echo"<td>";
 	while ($regi=mysql_fetch_array($regis)){
	
	echo $regi['e.nombre_esp']."</td>";
	
	
	
	}
	
		echo"</tr>";
		
  }
 
echo"</table>";
mysql_close($conexion);

?>
  #2 (permalink)  
Antiguo 27/06/2011, 11:57
 
Fecha de Ingreso: abril-2011
Mensajes: 1.342
Antigüedad: 12 años, 10 meses
Puntos: 344
Respuesta: proyecto php mysql varias consultas

El problema que creo que tienes es que especificas $regi['e.nombre_esp'] cuando debería ser $regi['nombre_esp'], sin el e..


Aun así, la forma que tienes de hacerlo no es buena, lo mejor es que hicieses una reunión con las tres tablas y te ahorrarías muchas consultas.

Código PHP:
Ver original
  1. <?php
  2. echo"<table border=0>";
  3. $conexion=mysql_connect("localhost","root","")
  4.   or  die("Problemas en la conexion");
  5. mysql_select_db("medicos",$conexion)
  6.   or  die("Problemas en la selección de la base de datos");
  7. $registros=mysql_query("select codigo,apellido,nombre,sexo,e.nombre_esp
  8.                       from doctores INNER JOIN doc_esp de ON doctores.codigo = doc_esp.codigo_doc
  9.                                     INNER JOIN  especialidades e ON de.codigo_esp = e.codigo_esp
  10.                                      order by apellido",$conexion) or
  11.   die("Problemas en el select:".mysql_error());
  12.  
  13. while ($reg=mysql_fetch_array($registros))
  14. {
  15.    
  16.     if($reg['sexo']=='M' or $reg['sexo']=='m'){
  17.     echo"<tr>";
  18.         echo "<td>"."Dr.".$reg['apellido']."&nbsp".$reg['nombre']."</td>";
  19.         echo "</tr>";
  20.         }
  21.     else{
  22.         echo"<tr>";
  23.         echo "<td>"."Dra.".$reg['apellido']."&nbsp".$reg['nombre']."</td>";
  24.        
  25.         }
  26.     echo"<td>";
  27.     echo $regi['nombre_esp']."</td>";
  28.         echo"</tr>";
  29.    
  30. }
  31.    
  32.    
  33.        
  34.  
  35.  
  36. echo"</table>";
  37. mysql_close($conexion);
  38.  
  39. ?>
  #3 (permalink)  
Antiguo 27/06/2011, 12:21
 
Fecha de Ingreso: junio-2011
Mensajes: 2
Antigüedad: 12 años, 9 meses
Puntos: 0
Respuesta: proyecto php mysql varias consultas

el problema es q no lo puedo hacer todo en un select por que me crear un producto cartesiano de tantos registros como cada doctor tenga especialidades ya que un doctor puede tener varias especialidades , lo q intente hacer es q en el primer while me traiga el apellido, nombre codigo, hacer otra consulta donde el where sea el codigo q me trajo y hacer otro while q me va traer la informacion de mi BD por cada doctor pero el problema lo tengo en la segunda consulta
  #4 (permalink)  
Antiguo 27/06/2011, 13:13
Avatar de PIRRUMAN  
Fecha de Ingreso: febrero-2006
Ubicación: Monterrey, Nuevo León
Mensajes: 633
Antigüedad: 18 años, 1 mes
Puntos: 53
Respuesta: proyecto php mysql varias consultas

para poder ayudarte mas deberias mostrar el error y para evitar productos cartesianos podrias probar con left join
__________________
“Prefiero ser un tonto momentaneo que un eterno ignorante”
“¡El éxito es resultado de los aciertos,los aciertos resultado de la experiencia y la experiencia resultado de los errores!”

Etiquetas: mysql, proyecto
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 01:37.