Foros del Web » Programando para Internet » Node.js »

node mysql, error

Estas en el tema de node mysql, error en el foro de Node.js en Foros del Web. Hola estoy haciendo consultas mysql con node. Pero tengo un problema al contar los datos y ejecutar otra consulta seguido de la anterior. @import url("http://static.forosdelweb.com/clientscript/vbulletin_css/geshi.css"); ...
  #1 (permalink)  
Antiguo 20/01/2013, 19:54
Jnl
 
Fecha de Ingreso: octubre-2012
Mensajes: 15
Antigüedad: 11 años, 6 meses
Puntos: 1
node mysql, error

Hola estoy haciendo consultas mysql con node.
Pero tengo un problema al contar los datos y ejecutar otra consulta seguido de la anterior.

Código Javascript:
Ver original
  1. totalconteo = 0;
  2. db.query("SELECT COUNT(*) AS totalR FROM usuarios",function(err,rows,fields)
  3.     {
  4.         if(err) throw err;
  5.         totalconteo = rows[0].totalR ;
  6.               console.log("conteo 1 =  "+ totalconteo );
  7.     });
  8. db.query("INSERT INTO info SET  nombre = ?, apellido = ?, direccion = ?",['minombre','miapellido','midireccion']);
  9.  
  10.  console.log("conteo 2 =  "+ totalconteo );
  11.  
  12. //imprime
  13. conteo 2 =  0
  14. conteo 1= 10

por que imprime en ese orden y no puedo obtener la variable luego para el resto del script.
  #2 (permalink)  
Antiguo 20/01/2013, 21:06
Avatar de Aijoona
Colaborador
 
Fecha de Ingreso: mayo-2011
Ubicación: Buenos Aires
Mensajes: 779
Antigüedad: 13 años
Puntos: 343
Respuesta: node mysql, error

Te falto leer la documentación, por defecto (casi) todas las operaciones I/O (input/output) en node.js son asincronicas.

Es decir, a diferencia de PHP (por dar un ejemplo general), el código no se ejecuta secuencialmente. Por esta misma razon, los callbacks tienen tanta importancia.

Te diría que sigas algún tutorial o manual más o menos básico, ya que tu dudas son bastante importantes.
__________________
blog | @aijoona
  #3 (permalink)  
Antiguo 21/01/2013, 11:20
Jnl
 
Fecha de Ingreso: octubre-2012
Mensajes: 15
Antigüedad: 11 años, 6 meses
Puntos: 1
Respuesta: node mysql, error

Gracias amigo.

Pero como puedo hacer para que me devuelva las respuestas en orden?.

Estoy haciendo una aplicación que primero valida al usuario y devuelve una respuesta, luego hace los mismo pero consultando su perfil y envía la siguiente respuesta.

En ese orden.
  #4 (permalink)  
Antiguo 21/01/2013, 20:40
 
Fecha de Ingreso: noviembre-2009
Ubicación: 127.0.0.1
Mensajes: 31
Antigüedad: 14 años, 5 meses
Puntos: 1
Respuesta: node mysql, error

Tendrías que anidar un callback dentro de otro :

Código Javascript:
Ver original
  1. db.query("...",function(){
  2.  // print
  3.  db.query("...",function(){
  4.   // print
  5.   db.query("...",function(){
  6.    // print
  7.   });
  8.  });
  9. });

Recuerda estudiar primero la documentación.

Etiquetas: javascript, mysql, node
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 17:43.