Foros del Web » Programando para Internet » PHP »

Fatal Error con la funcion Execute() en ADO.

Estas en el tema de Fatal Error con la funcion Execute() en ADO. en el foro de PHP en Foros del Web. Hola gente, a ver si me podeis echar un cable un cable con un problema que me he encontrdo! Antetodo, realizido la conexion con ADOdb ...
  #1 (permalink)  
Antiguo 25/05/2012, 10:42
 
Fecha de Ingreso: septiembre-2011
Mensajes: 87
Antigüedad: 12 años, 7 meses
Puntos: 6
Fatal Error con la funcion Execute() en ADO.

Hola gente, a ver si me podeis echar un cable un cable con un problema que me he encontrdo!

Antetodo, realizido la conexion con ADOdb hacia oracle, utilizando oci8.

Código PHP:
<?php

/**
 * @author Joanan
 * @copyright 2012
 */

session_start();
$session session_id(); 
//Incluir la clase que hace permite conexión a Oracle
include ('./adodb5/adodb.inc.php'); 
include (
'./adodb5/adodb-pager.inc.php');
include (
'./adodb5/adodb-exceptions.inc.php');

//Crear Conexión:
$DB ADONewConnection('oci8');
$DB->connectSID true;

//Datos de conexion
//$ip_servidor ="10.0.0.5"; //Sí Php y Oracle están en la misma máquina
$ip_servidor ="10.4.2.120"//Sí Php y Oracle están en la misma máquina
//en caso contrario incluir la ip del servidor oracle
$user ="f1";
$password ="f1";
$sid ="BD";


//Conexion
$con=$DB->PConnect($ip_servidor$user$password$sid);
echo 
"conexion--->$con";
//Sí se establece la conexión el resultado es 1


$sql="select * from equip order by equ_nom";

$recordSet $con -> Execute($sql); 

    
if (!
$recordSet){
    print 
$con->ErrorMsg();
}else {    
    print 
"OK";
}

$recordSet->Close(); # optional
$con->Close(); # optional
?>
No se porque me lanza un, Fatal error: Call to a member function Execute() on a non-object in C:\xampp\htdocs\2n curs\SINTESI\Conexio.php on line 36.

Llevo 3 horas mirando el que i nada.

gracias.
  #2 (permalink)  
Antiguo 25/05/2012, 10:51
Avatar de newboy_master  
Fecha de Ingreso: enero-2008
Ubicación: Granada
Mensajes: 882
Antigüedad: 16 años, 3 meses
Puntos: 46
Respuesta: Fatal Error con la funcion Execute() en ADO.

Hablo desde la ignorancia, ¿no deberías poner 'new' al instanciar la clase?

Código PHP:
Ver original
  1. $DB = new ADONewConnection('oci8');

Si no te funciona dímelo y lo reviso bien.

Salu2.
__________________
@jslirola - Programador Web Freelance.
  #3 (permalink)  
Antiguo 25/05/2012, 10:52
Avatar de jotaincubus  
Fecha de Ingreso: mayo-2005
Ubicación: Medellin - Colombia
Mensajes: 1.797
Antigüedad: 19 años
Puntos: 394
Respuesta: Fatal Error con la funcion Execute() en ADO.

Cambia:

$recordSet = $con -> Execute($sql);

por

$recordSet = $DB -> Execute($sql);

ademas de lo que dice el post anterior y dinos si te funciona...
__________________
Por que existe gente que no agradece después de que se le ha brindado tiempo y ayuda ???
  #4 (permalink)  
Antiguo 25/05/2012, 10:58
 
Fecha de Ingreso: septiembre-2011
Mensajes: 87
Antigüedad: 12 años, 7 meses
Puntos: 6
Respuesta: Fatal Error con la funcion Execute() en ADO.

como dices tu jotaincubus!!! merci cracks!, lo de new no hace falta.
  #5 (permalink)  
Antiguo 25/05/2012, 12:04
 
Fecha de Ingreso: septiembre-2011
Mensajes: 87
Antigüedad: 12 años, 7 meses
Puntos: 6
Respuesta: Fatal Error con la funcion Execute() en ADO.

como veis si englobo toda la conexion de antes en una clase?? He hecho algo asi, lo k no me devuelve la conexion.

Código PHP:
Ver original
  1. Class GestorBD{
  2.    
  3.     private $ip_servidor;
  4.     private $user;
  5.     private $password;
  6.     private $sid;
  7.     private $BD;
  8.    
  9.     public static function getInstance(){
  10.  
  11.         $BD = ADONewConnection('oci8');
  12.         $BD->connectSID = true;
  13.        
  14.         //Datos de conexion
  15.         //$ip_servidor ="10.0.0.5"; //Sí Php y Oracle están en la misma máquina
  16.         $ip_servidor ="10.4.2.120"; //Sí Php y Oracle están en la misma máquina
  17.         //en caso contrario incluir la ip del servidor oracle
  18.         $user ="f1";
  19.         $password ="f1";
  20.         $sid ="BD";
  21.        
  22.        
  23.         //Conexion
  24.         $DB->PConnect($ip_servidor, $user, $password, $sid);
  25.    
  26.         return $BD;
  27.     }
  28. }

lugo recojeria la conexion asi:

$BD = GestorBD::getInstance();

nose, me dice lo de antes, el fatal error.
  #6 (permalink)  
Antiguo 25/05/2012, 12:39
Avatar de jotaincubus  
Fecha de Ingreso: mayo-2005
Ubicación: Medellin - Colombia
Mensajes: 1.797
Antigüedad: 19 años
Puntos: 394
Respuesta: Fatal Error con la funcion Execute() en ADO.

Por lo que veo queres utilizar el patron Singleton.... si es asi, lee un poco y rearma tu codigo porque asi no te funcionara.
__________________
Por que existe gente que no agradece después de que se le ha brindado tiempo y ayuda ???

Etiquetas: execute, fatal, funcion, sql
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 06:16.