Foros del Web » Programando para Internet » PHP »

Comparacion de consultas mysql con php (arrays)

Estas en el tema de Comparacion de consultas mysql con php (arrays) en el foro de PHP en Foros del Web. Hola... espero me puedan ayudar tengo dos consultas en mysql... que al final llamandolas con PHP dan algo así. Consulta1 "SELECT id_proy...." ... $row_v = ...
  #1 (permalink)  
Antiguo 03/04/2010, 02:23
 
Fecha de Ingreso: abril-2010
Mensajes: 34
Antigüedad: 14 años
Puntos: 1
Exclamación Comparacion de consultas mysql con php (arrays)

Hola... espero me puedan ayudar

tengo dos consultas en mysql... que al final llamandolas con PHP dan algo así.

Consulta1 "SELECT id_proy...."

...

$row_v = mysql_fetch_array($result_v);

Consulta 2 "SELECT id_proy, dato..."

...

$row_f = mysql_fetch_array($result_f);

a pues estos kiero compararlos algo asi...

if($row_v['id_proy'] == $row_f['id_proy'])

print row_f['dato']; // Imprima "dato" justo donde cumple con la igualdad

esto adentro de un while...

cabe destacar que si lo hago con un LEFT JOIN en mysql tarda demasiado mi consulta es por eso que busco el como compararla y dar el resultado con PHP.

Gracias y Saludos!!
  #2 (permalink)  
Antiguo 03/04/2010, 03:41
Avatar de AnesGy  
Fecha de Ingreso: mayo-2009
Mensajes: 518
Antigüedad: 14 años, 11 meses
Puntos: 19
Respuesta: Comparacion de consultas mysql con php (arrays)

voy a proponerte una función:

Código PHP:
Ver original
  1. function compara_arrays($array_a, $array_b){
  2.  if(($j = count($array_a)) != count($array_b)) return false;
  3.  for($i = 0; $i < $j; $i++) if($array_a[$i] !== $array_b[$i]) return false;
  4.  return true;
  5. }

En 5 líneas tienes un comparador de array.
__________________
Si alguna vez parece que soy grosero, pido perdón, es un intento fallido de ser directo.

AnesGy SD. Name it, Get it
  #3 (permalink)  
Antiguo 03/04/2010, 07:13
Avatar de mauroave  
Fecha de Ingreso: julio-2009
Mensajes: 50
Antigüedad: 14 años, 9 meses
Puntos: 0
Respuesta: Comparacion de consultas mysql con php (arrays)

y si lo haces con join natural, construyendolo asi...
Código PHP:
$mysql_cons=mysql_query("SELECT * FROM tabla1,tabla2 WHERE tabla1.campo_en_comun=tabla2.campo_en_comun");

while(
$row=mysql_fetch_array($mysql_cons))
    {
    
//hacer aca lo que quieras hacer con los datos, por ejemplo mostrarlos
    
echo $row[1];
    } 
  #4 (permalink)  
Antiguo 03/04/2010, 11:30
 
Fecha de Ingreso: abril-2010
Mensajes: 34
Antigüedad: 14 años
Puntos: 1
Respuesta: Comparacion de consultas mysql con php (arrays)

lo intente... pero has de cuenta que como tambien necesito que se muestre informacion de otra tabla y se unan con toda... es decir... tiene una tabla de proyectos en la cual necesito ver todos sus proyectos y en la otra tabla viene la informacion de que a echo con esos proyectos... pero si los uno con un JOIN natural y no a echo actividades con ese proyecto simplemente no lo muestra... y en este caso deberia mostrarlos... mis codigos completos serian estos...
Cita:
/*********************INICIO VISUALIZACIÓN DE LOS PROYECTOS DE USUARIO Y LLENADO DE CEDULA*************/
$sql = "SELECT p.id_proyecto, p.proyecto, COUNT(c.id_proyecto) as conteoc, DATE_FORMAT( MAX(c.f_genced), '%d-%m-%Y' ) AS f_genced
FROM proyectos as p, user_proyectos as u
LEFT JOIN cedula as c ON u.id_proyecto = c.id_proyecto
WHERE u.id_usuario = ".$id_usuario."
AND u.id_proyecto = p.id_proyecto
AND p.activo = 1
GROUP BY p.id_proyecto
ORDER BY p.proyecto";
$result_v = mysql_query($sql);
$row_v = mysql_fetch_array($result_v);
/*********************FIN VISUALIZACIÓN DE LOS PROYECTOS DE USUARIO Y LLENADO DE CEDULA*************/
/**************INICIO CONSULTA DE CONTEO DE VISITAS AL PROYECTO Y ULTIMA VISITA***********/
$sql = "SELECT r.id_proyecto, p.proyecto, COUNT(r.id_proyecto) AS conteo, DATE_FORMAT( MAX(r.f_actividad), '%d-%m-%Y' ) AS f_visita
FROM proyectos as p, user_proyectos as u
LEFT JOIN rdas AS r ON u.id_proyecto = r.id_proyecto
WHERE u.id_usuario = ".$id_usuario."
AND r.f_actividad >= '$d_ini'
AND r.f_actividad <= '$d_fin'
AND u.id_proyecto = p.id_proyecto
AND p.activo = 1
GROUP BY r.id_proyecto
ORDER BY p.proyecto";
$result_c = mysql_query($sql);
$row_c = mysql_fetch_array($result_c);
/**************FIN CONSULTA DE CONTEO DE VISITAS AL PROYECTO Y ULTIMA VISITA***********/
La intencion es que donde sean iguales se unan...
  #5 (permalink)  
Antiguo 03/04/2010, 19:56
 
Fecha de Ingreso: abril-2010
Mensajes: 34
Antigüedad: 14 años
Puntos: 1
Respuesta: Comparacion de consultas mysql con php (arrays)

Hola Anes... voy iniciando en PHP... con esta unción hay posibiladad de unir la función??
  #6 (permalink)  
Antiguo 04/04/2010, 06:27
Avatar de AnesGy  
Fecha de Ingreso: mayo-2009
Mensajes: 518
Antigüedad: 14 años, 11 meses
Puntos: 19
Respuesta: Comparacion de consultas mysql con php (arrays)

Cita:
con esta unción hay posibiladad de unir la función??
Como? La función k te propongo compara arrays (que no árboles de nodos, que son arrays que contienen arrays). Sirve para comparar los resultados arrojados por dos $row = mysql_fetch_assco($result).
__________________
Si alguna vez parece que soy grosero, pido perdón, es un intento fallido de ser directo.

AnesGy SD. Name it, Get it

Etiquetas: arrays, comparacion, mysql
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:43.