Foros del Web » Programando para Internet » PHP »

Como usar la variable $_POST en una consulta SQL para Oracle

Estas en el tema de Como usar la variable $_POST en una consulta SQL para Oracle en el foro de PHP en Foros del Web. Hola amigos del Foro del Web : Tengo un problema con un formulario que utiliza un listbox que recupera los datos desde una base de ...
  #1 (permalink)  
Antiguo 31/05/2007, 12:12
 
Fecha de Ingreso: mayo-2007
Mensajes: 8
Antigüedad: 16 años, 11 meses
Puntos: 0
Pregunta Como usar la variable $_POST en una consulta SQL para Oracle

Hola amigos del Foro del Web:
Tengo un problema con un formulario que utiliza un listbox que recupera los datos desde una base de datos en Oracle, esto lo hago por medio de una conexión.
Cuando en el formulario utilizo la sentencia <select> así:
<form action="pruebaOracle_graf.php" method="post">
<p>INDICADOR &nbsp;
<select style="WIDTH: 504px" name="{miDato_Name}">
<option value="" selected>Seleccione&nbsp;indicador</option>
{miDato_Options}
</select>

<!-- BEGIN Button Button1 --><input type="submit" value="Consultar" name="{Button_Name}"><!-- END Button Button1 --></p>


Utilizo un boton que envía los datos del select por medio del método POST a la página "pruebaOracle_graf.php" ,esta página utiliza unas consultas SQL para conexión a una base de datos en Oracle, tal como la siguiente:

if(isset($_POST['miDato_Name'])){
$dato = $_POST['miDato_Name'];
}
$query = "select a.valor_indicador from sise_indicadores_sum a where a.codigo_indicador='$dato' order by a.anio";
$s = OCIParse($c, $query);
OCIExecute($s);
$data = array();

while ($row = oci_fetch_array($s, OCI_RETURN_NULLS)) {
$data[] = $row[0];
}


En donde la idea es utilizar los datos que fueron enviados y guardados en el arreglo de la variable $_POST, entonces yo intento recogerlos en la varible $dato por medio de: $dato = $_POST['miDato_Name']; y cuando necesito incluirlo en la consulta SQL hago que $dato se mande a llamar así: $query = "select a.valor_indicador from sise_indicadores_sum a where a.codigo_indicador='$dato' order by a.anio";

Se supone que la consulta SQL está bien, y también se supone que la página "pruebaOracle_graf.php" hace estas consultas para graficar los datos por medio de las librerías JpGrahp para php.

Cuando presiono el boton con value="Consultar" me carga la página "pruebaOracle_graf.php" y me envía un error, de esos que la librería JpGrahp envía cuando no puede graficar porque dice que la sumatoria de los datos suman cero.

Entonces: Pregunto a alguien que me pueda ayudar:
¿Qué estoy haciendo mal?
¿Será que tengo algún problema en el formulario?
¿Tengo que activar algo en el php.ini para utilizar las variables $_POST?
¿o sucede algo que aun no he descubierto?

Espero deje por entendido mi problema y si alguien sabe como puedo resolverlo, su ayuda será bien recibida.

Que DIOS todo Poderoso los bendiga!!!
  #2 (permalink)  
Antiguo 01/06/2007, 11:20
Avatar de edwinandlozano  
Fecha de Ingreso: octubre-2003
Mensajes: 272
Antigüedad: 20 años, 6 meses
Puntos: 0
Re: Como usar la variable $_POST en una consulta SQL para Oracle

hola..

bueno primero que nada, ya probaste si en realidad $dato con tiene la info que necesitas y que a su vez la consulta devuelve datos??
imprime la variable que contiene la consulta ($sql):
print "<pre>";
var_dump($sql);
print "</pre>";

con la salida que te arroge puedes copiar y pegar la sentencia en un cliente sql y verificar si te devuelve los datos que necesitas...

nos vemos.
  #3 (permalink)  
Antiguo 03/06/2007, 20:56
Avatar de BrujoNic
Super Moderador
 
Fecha de Ingreso: noviembre-2001
Ubicación: Costa Rica/Nicaragua
Mensajes: 16.935
Antigüedad: 22 años, 5 meses
Puntos: 655
Re: Como usar la variable $_POST en una consulta SQL para Oracle

Trasladado de BD a PHP.

Función de la sección de Base de Datos
__________________
La tecnología está para ayudarnos. No comprendo el porqué con esa ayuda, la gente escribe TAN MAL.
NO PERDAMOS NUESTRO LINDO IDIOMA ESPAÑOL
  #4 (permalink)  
Antiguo 04/06/2007, 09:11
 
Fecha de Ingreso: mayo-2007
Mensajes: 8
Antigüedad: 16 años, 11 meses
Puntos: 0
Pregunta Re: Como usar la variable $_POST en una consulta SQL para Oracle

Hola edwinandlozano:

Utilice las instrucciones que me aconsejaste. Las pegue en el archivo php después de hacer la consulta SQL y el resultado que desplegó fue el siguiente:

string(96) "select a.valor_indicador from sise_indicadores_sum a where a.codigo_indicador='' order by a.anio"

Como verás, en la parte del WHERE, en a.codigo_indicador=' ' no aparece la variable $dato, que es la que utilizo para recoger lo que se envía con la variable $_POST.

Entonces que sucede, será que el evento del botón que utilizo en el formulario no envía la selección que hago en el listbox del html y no lo guarda en la variable $_POST, porque no grafica los datos que necesito

¿Qué puedo hacer? ¿Alguna idea?
  #5 (permalink)  
Antiguo 04/06/2007, 09:29
 
Fecha de Ingreso: mayo-2007
Mensajes: 8
Antigüedad: 16 años, 11 meses
Puntos: 0
Pregunta Re: Como usar la variable $_POST en una consulta SQL para Oracle

Hola de nuevo edwinandlozano:

Estuve haciendo otras pruebas, lo que hice es darle un valor por defecto a la variable $dato; así:

$dato = 225;
$query = "select a.valor_indicador from sise_indicadores_sum a where a.codigo_indicador='$dato' order by a.anio";

con esto hace lo que yo quiero que haga.
El problema ahora radica en que la variable $dato = $_POST['miDato_Name']; no hace lo que se supone tiene que hacer.
Estoy notando que la variable $_POST que es la que guarda lo que se le envía por medio de un formulario, no está guardando nada. Entonces que tengo que hacer para solventar este problema. Porque estoy viendo que el problema está en la correcta utilización de los formularios y en especial del envío de los datos por medio de la variable $_POST[] y como utilizarla.

¿Que me recomiendas? ¿Cómo puedo proceder?
Por tu ayuda y sugerencias. Muchas gracias.
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:03.