Foros del Web » Programando para Internet » PHP »

fetch_row y fetch_array ??

Estas en el tema de fetch_row y fetch_array ?? en el foro de PHP en Foros del Web. Hola Amigos, Me gustaría si alguienpudiera explicarme cuales serian los casos de uso para cada una de las funciones de mysql porque no logro entender ...
  #1 (permalink)  
Antiguo 09/03/2006, 15:54
Avatar de Juanmax  
Fecha de Ingreso: diciembre-2005
Ubicación: Paraná, Entre Ríos , Argentina
Mensajes: 90
Antigüedad: 12 años
Puntos: 0
fetch_row y fetch_array ??

Hola Amigos,
Me gustaría si alguienpudiera explicarme cuales serian los casos de uso para cada una de las funciones de mysql porque no logro entender el funcionamiento exacto de estas dos.

Muchísimas gracias.

PDTA: Deseenme suerte, mañana presento mi proyecto para terminar la carrera de analista y mucho de lo aprendido se lo debo al Foro. Un abrazo.
__________________
juanmax - GUERRERO Lab
  #2 (permalink)  
Antiguo 09/03/2006, 16:06
Avatar de nicolaspar  
Fecha de Ingreso: noviembre-2004
Ubicación: Villa Ballester Bs-As|Ar
Mensajes: 2.002
Antigüedad: 13 años
Puntos: 34
Ambas generan un vector de los resultados. También esta mysql_fetch_assoc.
Entonces:
mysql_fetch_row:
Genera un vector no asociativo, esto sería del tipo:
$arr[] = "uno";
$arr[] = "dos";
Donde $arr[0]= uno y $arr[1] = dos.
mysql_fetch_assoc: Genera un vector asociativo, ej:
$arr["algo"] = "uno";
$arr["algomas"] = "dos";
Donde $arr["algo"]= uno y $arr["algomas"] = dos.
mysql_fetch_array te genera ambos, pudiendo acceder mediante posición o indice.

Ahora bien, la diferencia esta en memoria. Si tenes una consulta gigante, el espacio en memoria que generara mysql_num_row será mucho menor a lo que generaría mysql_fetch_assoc, y ni hablar si usas mysql_fetch_array.
En si, si los campos que traes son pocos (digamos, dos, tres, ... no mas de cinco) usa mysql_fetch_row que es mas óptimo.
Si son mas es conveniente usar mysql_fetch_assoc así tendrás mas comodidad y será mas legible haciendo $rs["campo"] que $rs[X].

También vale decir que mysql_fetch_array dispone de un segundo parámetro opcional que es el tipo de vector a generar. O sea, se puede decir que mysql_fetch_array es un híbrido entre los otros dos, a no ser que se especifique lo contrario, ej:
while( $rs = mysql_fetch_array( $puntero, TIPO )...
TIPO Pude ser: MYSQL_ASSOC (Asolo asociativo), MYSQL_NUM, solo por posición, y el default que no es necesario MYSQL_BOTH.

No se si te mezcle mucho, o te ha ayudado...espero que la segunda ;)

Saludos
__________________
Mi punto de partida es Que Bueno Lo Nuevo
  #3 (permalink)  
Antiguo 09/03/2006, 16:09
Avatar de vevni  
Fecha de Ingreso: julio-2005
Ubicación: cancun mexico
Mensajes: 598
Antigüedad: 12 años, 4 meses
Puntos: 3
de acuerdo totalmente con lo de nicolaspar..!!
saludos!!!
__________________
Código PHP:
echo"hola mundo ver 1221332143.02";
echo
"cuantos usuarios habran impreso hola mundo en el mundo.!???"
  #4 (permalink)  
Antiguo 09/03/2006, 16:21
Avatar de Juanmax  
Fecha de Ingreso: diciembre-2005
Ubicación: Paraná, Entre Ríos , Argentina
Mensajes: 90
Antigüedad: 12 años
Puntos: 0
MUCHÍSIMAS GRACIAS NICOLASPAR..
Un abrazo..
__________________
juanmax - GUERRERO Lab
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:11.