Foros del Web » Programando para Internet » PHP »

PHP OO insertar en una tabla

Estas en el tema de insertar en una tabla en el foro de PHP en Foros del Web. estoy intentado hacer un insertar en una tabla , y todo correcto , pero al hacer un procedimiento que es el siguiente : function logon_on($idpersona,$nom){ ...
  #1 (permalink)  
Antiguo 08/06/2014, 06:25
 
Fecha de Ingreso: junio-2014
Mensajes: 2
Antigüedad: 9 años, 10 meses
Puntos: 0
insertar en una tabla

estoy intentado hacer un insertar en una tabla , y todo correcto , pero al hacer un procedimiento que es el siguiente :

function logon_on($idpersona,$nom){
$sql = sprintf('insert into logon (id_persona, userlog, dia_logon, hora_logon, aon, taula) values ("%s", "%s","%s","%s", "0","0")', $idpersona,$nom,date('Y-m-d'),date("H:i:s",time()), "0","0" );
$res = @mysqli_query($conn,$sql);


}
Me dice que la variable $conn no esta definidad.
La variable con es la variable de conexion : $conn=@mysqli_connect(HOST,USER,PASSWORD,DATABASE) or die ('Error al conectar en la Base de Datos: ');

Si copio el codigo de la funcion logon en la pagina de php me funciona pero al crear el procedimento y llamarlo desde la pagina

:logon_on($datos['id_categoria'],$datos['userlog']);

me da el error antes comentado me podéis ayudar gracias
es decir me funciona, pero al intentar separar el codigo insert en un procedimiento y llamarlo no .
  #2 (permalink)  
Antiguo 08/06/2014, 07:10
Avatar de Italico76  
Fecha de Ingreso: abril-2007
Mensajes: 3.303
Antigüedad: 17 años
Puntos: 292
Respuesta: insertar en una tabla

Bueno... lo que pasa es que desde el ambito de la funcion logon_on() no puedes ver variables definidas fuera como $conn excepto sea global:

Cita:
function logon_on($idpersona,$nom)
{
global $conn;
$sql = sprintf('insert into logon (id_persona, userlog, dia_logon, hora_logon, aon, taula) values ("%s", "%s","%s","%s", "0","0")', $idpersona,$nom,date('Y-m-d'),date("H:i:s",time()), "0","0" );
$res = @mysqli_query($conn,$sql);
...
No te estoy diciendo que uses variables globales......sino porque el error
__________________
Salu2!
  #3 (permalink)  
Antiguo 08/06/2014, 08:33
 
Fecha de Ingreso: junio-2014
Mensajes: 2
Antigüedad: 9 años, 10 meses
Puntos: 0
Respuesta: insertar en una tabla

Y la solución cual es convertirla en global
  #4 (permalink)  
Antiguo 08/06/2014, 08:41
Avatar de Italico76  
Fecha de Ingreso: abril-2007
Mensajes: 3.303
Antigüedad: 17 años
Puntos: 292
Respuesta: insertar en una tabla

La solucion "buena" es hacer todo completamente distinto..... encapsular todo en una clase y entonces la conexion a la DB seria una propiedad de la clase a la que puedes acceder de forma privada.
__________________
Salu2!

Etiquetas: mysql, sql, tabla, variable
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 12:55.