Foros del Web » Programando para Internet » PHP »

mysqli->fetch

Estas en el tema de mysqli->fetch en el foro de PHP en Foros del Web. Hola como están ? Bueno estoy al borde de un colapso jaja ... Cuando intento obtener los resultados de mysqli->fetch y guardarlos en un array ...
  #1 (permalink)  
Antiguo 11/12/2011, 22:12
 
Fecha de Ingreso: agosto-2011
Mensajes: 161
Antigüedad: 12 años, 7 meses
Puntos: 7
mysqli->fetch

Hola como están ?

Bueno estoy al borde de un colapso jaja ...

Cuando intento obtener los resultados de mysqli->fetch y guardarlos en un array
este no me los guarda...
Creo que la manera en el que estoy guardando los datos dentro de un array no es la correcta..

Este es mi script..
http://www.subirimagenes.com/otros-q...n-7229239.html

Lo hice asi pues, es la manera comun con mysql.

luego de guardar los datos..
la idea es
hacer un siclo for .. eh ir mostrando las columnas..
ej..
echo reg[$i]["columna1"] ...

Espero no haber sido un poco enrredado :) ...
Muchas gracias por tu tiempo!.
  #2 (permalink)  
Antiguo 11/12/2011, 23:40
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 7 meses
Puntos: 2237
Respuesta: mysqli->fetch

Y si agregas un return $datos; funciona?

Por cierto, es más fácil ayudarte si colocas aquí mismo el código. No todos hacen click en enlaces a páginas externas para saber de qué se trata.
__________________
- León, Guanajuato
- GV-Foto
  #3 (permalink)  
Antiguo 12/12/2011, 06:51
 
Fecha de Ingreso: agosto-2011
Mensajes: 161
Antigüedad: 12 años, 7 meses
Puntos: 7
Respuesta: mysqli->fetch

Tienes toda la razon, pero no voy a eso... jaja ..
pues.. La manera en el cual estoy imprimiento en la pantalla esta mal ya que el mysqli->fetch .. no se si es assoc.. o un obj .. o fetch_array .. entonces.. eh intentado de artas formas..

hago lo siguiente

$mysqli=$this->mysqli;
$datos = array();
$sql="select * from nk where id= ? ";
$stmt=$mysqli->prepare($sql);
$stmt->bind_param('s',$id);
$stmt->execute();
$stmt->bind_result($id,$detalle,$titulo,$fecha_ini,$fech a_ter,$algo);

while($reg=$stmt->fetch())
{
$datos[]=$reg // creo que esta manera esta mal.

}
echo $datos[0]

Gracias por tu tiempo !
  #4 (permalink)  
Antiguo 12/12/2011, 12:58
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 7 meses
Puntos: 2237
Respuesta: mysqli->fetch

Código PHP:
Ver original
  1. $stmt->bind_result($id,$detalle,$titulo,$fecha_ini,$fech a_ter,$algo);
  2.  
  3. while($stmt->fetch()) {
  4.     $datos[]=array($campo1, $campo2, $campo3, $etc);
  5. }

Creo que fetch simplemente lee la fila y extrae las columnas, creando las variables necesarias.
__________________
- León, Guanajuato
- GV-Foto
  #5 (permalink)  
Antiguo 12/12/2011, 19:57
 
Fecha de Ingreso: agosto-2011
Mensajes: 161
Antigüedad: 12 años, 7 meses
Puntos: 7
Respuesta: mysqli->fetch

Gracias trby ! funciono perfecto..
Tengo una duda... solo si me puedes responder campeon.. :)


En este minuto tengo dos script con mysqli que tienen el mismo objetivo pero varian en lo siguiente:

uno prepara la consulta y el otro tiene un mysqli->real_escape_string.
Se supone que los dos evitan injection SQL.

pues cual es la diferencia ?...

Lo otro:
Cuando preparo una consulta me genera un codigo mas largo, pero leyendo algunos articulos, se supone que el rendimiento es mejor pues le avisamos a la database cuales son los tipos de archivos que van a entrar.
No si se alguna vez has probado mysqli_prepare y ver el rendimiento.

aqui van los script: CON MYSQL->PREPARE

Código PHP:
public function get_datos($nomkey)
    {
       
$mysqli=$this->mysqli;
       
$datos = array();
       
$sql="select * from nk where nomkey= ? ";
       
$stmt=$mysqli->prepare($sql);
       
$stmt->bind_param('s',$nomkey);
       
$stmt->execute();
       
$stmt->bind_result($campo1,$campo2,$campo3,$campo4,$campo5,$campo6);
       while(
$stmt->fetch()):
       
          
$datos[]=array($campo1,$campo2,$campo3,$campo4,$campo5,$campo6);
           
       endwhile;
     
        
        return 
$datos;
    } 
//end method 

y aqui el segundo script el cual tiene mysqli->real_escape_string

Código PHP:
$mysqli=$this->mysqli;
            
$datos=array();
            
$nomkey=$mysqli->real_escape_string($nomkey);
            
$sql="select * from nk where nomkey ='".$nomkey."'";
            
$res=$mysqli->query($sql);
            while(
$reg=$res->fetch_object()):
            
            
$datos[]=$reg;
            
            endwhile;
            
            return 
$datos;
            }
// end function */ 

Segun tengo entendido con prepare tengo mayor seguridad, pero que pasa con el rendimiento ? .. ya que se genera un codigo mas largo.

Gracias !
  #6 (permalink)  
Antiguo 12/12/2011, 20:55
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 7 meses
Puntos: 2237
Respuesta: mysqli->fetch

Preprarando las consultas, en teoría, obtienes mejor rendimiento, pero esto es un tanto relativo porque la diferencia no es significativa, a menos que tengas alto volumen de datos y yo me inclinaría más por la seguridad... otro punto a favor de preparar.

Aclaro que nunca he usado mysqli, preferí migrar directamente a PDO.
__________________
- León, Guanajuato
- GV-Foto
  #7 (permalink)  
Antiguo 12/12/2011, 21:12
 
Fecha de Ingreso: agosto-2011
Mensajes: 161
Antigüedad: 12 años, 7 meses
Puntos: 7
Respuesta: mysqli->fetch

Muchas gracias triby ! ... te pasaste campeon ! ..

Etiquetas: html, 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 05:56.