FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Llamada a procedimiento Oracle
Hola, este es el primer hilo que abro despues de leer muchos otros que me han servido de mucha ayuda pero para el problema que se me presenta actualmente no he encontrado respuesta.
La pregunta es la siguiente: Estoy utilizando ADO+Oracle en una aplicacion hecha en Builder 2006. Accedo a una BBDD remota en donde se encuenta un procedimiento almacenado que quiero ejecutar pero no encuentro la forma correcta. El procedimiento tiene la forma siguiente: procedimiento( aaa IN number, bbb IN number, ccc IN number, ddd IN number, eee IN number, codigo_error OUT number ) El tema es que no se como conseguir el dato codigo_error ... Yo tengo algo asi pero me falta saber como recuperar el ultimo parametro... DECLARE salida number; BEGIN procedimiento(a,b,c,d,e,???); ??????? END; (Siento si he escrito alguna tonteria pero no estoy acostumbrado a pl sql) Gracias. |
#2
|
||||
|
||||
ADO tiene un componente TAdoStoredProc. Configuralo con el nombre del procedimiento y ceará automáticamente los parámetros, tanto de entrada como de salida.
Así, podes finalmente tener algo como:
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#3
|
|||
|
|||
gracias por la respuesta, es mucho mas comodo utilizar ese componente (no sabia que existia), ahora tengo otro problema: cuando hago el ExecProc me devuelve el siguiente error:
"One or more errors occurred during processing of command" El codigo es este: //cargo los valores de entrada del procedimiento proc->Parameters->ParamByName("aaa")->Value = xxx; proc->Parameters->ParamByName("bbb")->Value = xxx; proc->Parameters->ParamByName("ccc")->Value = xxx; proc->Parameters->ParamByName("ddd")->Value = xxx; proc->Parameters->ParamByName("eee")->Value = xxx; //ejecuto el procedimiento proc->Prepared = true; proc->ExecProc(); //luego recogeria el dato que devuelve el procedure ... |
#4
|
||||
|
||||
Cita:
Detesto ADO... no lo uso mas que cuando sea necesario, precisamente por esto: sus mensajes de error no son nada claros. Lamento no ser de mucha ayuda. Lo que se me ocurre es probar en el SQL*Plus la ejecución del procedimiento directamente usando los parámetros con los que se invoca desde delphi, y si hay información de estado en el contexto (sesión, valores en tablas, etc.), pues que el estado también sea el mismo. Esto porque es MUY probable que se esté elevando una excepción desde el propio Oracle, pero que ADO se trague el mensaje de error original y lo sustituya por uno propio. (no es la primera vez que lo haría). Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#5
|
|||
|
|||
Pues no, mucho no me aclara ese error no. De todos modos gracias por la respuesta. Voy a seguir mirando de donde puede venir el fallo y cuando lo solucione lo comento aqui. Un saludo.
|
#6
|
|||
|
|||
bueno el TADOStoredProc me esta dando unos problemillas asi que estoy intentando ejecutar el procedimiento desde consultas "a mano".
El tema es que no controlo mucho de PL SQL y no se como recoger el parametro de salida del procedimiento... Tengo algo asi: (codigo c++) Código:
consulta = new TADOQuery(NULL); consulta->Connection = ADOConnection1; consulta->SQL->Add("declare codigo number; begin nombre_procedimiento(100,1,1,1,1,codigo); end; "); consulta->Prepared = true; consulta->ExecSQL(); ..... parametro 'codigo'. Ahora lo que necesito es recuperar ese valor y guardarlo en una variable int (por ejemplo) en mi aplicacion y no se como... |
#7
|
||||
|
||||
mmm.. francamente no creo que sea posible de esta manera, pues la variable se crea dentro del bloque anónimo de PL/SQL y existe solamente en el contexto de su ejecución. Dicha ejecución ya ha terminado cuando el control vuelve a Delphi.
Quizás funcione usando un parámetro. Estos se declaran con el signo de dos puntos.
Francamente no tengo idea si funcionará... Saludos.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate Última edición por jachguate fecha: 21-12-2007 a las 20:31:55. |
#8
|
|||
|
|||
Gracias jachguate por todas tus respuestas.
Bueno pues habra que volver a pelearse con el TADOStoredProc... estoy intentando partir de un ejemplo mas sencillo: tengo un proc almacenado que no tiene parametros de entrada, simplemente devuelve un numero (que se incrementa cada vez que se invoca el p.a.) el procedimiento se ejecuta bien pero no logro recoger el dato de vuelta... Cuerpo del procedimiento (de sql server en este caso): begin transaction update tabla_xxx set valor = valor + 1 where nombre = 'xxx' select valor from tabla_xxx where nombre = 'xxx' commit Como hago para recoger ese dato? Con un TADOQuery hago algo asi: String respuesta = consulta->Fields->operator [](0)->AsString; como hago desde el TADOStoredProc? Gracias. |
#9
|
||||
|
||||
¿esto está dentro de un stored procedure?
Si es así, al poner el nombre, automáticamente el componente debiera "crear" los parámetros de entrada y salida del mismo. Podes comprobarlo haciendo clic en el botón de los puntos suspensivos de la propiedad Params en el inspector de objetos. A dichos parámetros y sus propiedades tenes acceso mediante la propiedad "Params" del componente StoredProc. Podes obtener individualmente el valor de un parámetro específico así:
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#10
|
|||
|
|||
Olvidalo tio, alguien me ha pasado una descripcion de proyecto un tanto "erronea". No era un procedimiento almacenado, era una FUNCION !!
En fin, que ahora me mirare como invocar funciones... siento que hayas perdido asi el tiempo. (Mas he perdido yo xDD). Venga un saludo jachguate |
#11
|
||||
|
||||
Para invocar una función, podes poner en un query:
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#12
|
|||
|
|||
Hola de nuevo, utilizo oraedit para hacer las pruebas y en el escribo lo siguiente:
Esto funciona perfectamente, fijate en que necesito declarar cod antes de invocar a la funcion. Luego en mi aplicacion,en la query escribo: select XXX(8,888,1,3,3,0) from dual pero claro me dice que el ultimo parametro no es correcto: ORA-06572: La función XXX tiene argumentos externos entonces tengo que pasarle un parametro de tipo number que tengo que declarar antes pq si pongo directamente esto: select XXX(8,888,1,3,3,cod) from dual me contesta: "ORA-00904: \"COD\": identificador no válido" en resumen: tengo que definir primero el parametro cod. He probado haciendo un declare primero, algo asi: declare cod number;begin select XXX(8,888,1,3,3,cod) from dual; end; pero me devuelve: ORA-06550: línea 1, columna 26:\nPLS-00428: se espera una cláusula INTO en esta sentencia SELECT" tambien he intentado crear un parametro en la query: consulta->Parameters->CreateParameter("cod",ftInteger,pdInputOutput,20,0); (no existe el tipo de dato number asi que he utilizado integer...) y tampoco funciona, me contesta: ORA-00904: \"COD\": identificador no válido" Alguna idea? Gracias |
#13
|
||||
|
||||
esta es mi idea:
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#14
|
|||
|
|||
Desde SQL el problema es el parametro ese que es de salida (OUT)
hago lo que me pusiste: select XXX(2,2,2,2,2,:cod) from dual; pero me devuelve : ORA-06572: La función XXX tiene argumentos externos Y luego desde el codigo lo mismo:
(probe a acabar la sentencia con ; y sin el, probe con ftFloat,ftInteger..., probe con open() y con execsql() y nada ... ) me devuelve el mismo error: ORA-06572: La función XXX tiene argumentos externos segun este error no se puede invocar a funciones con parametros de salida sin embargo si defino primero la variable y luego lo invoco desde un bloque sql si que funciona ( ?¿?¿?¿?¿ )
Este codigo funciona bien. A alguien le ha pasado algo parecido ? Empiezo a odiar esto xD Gracias. |
#15
|
|||
|
|||
Hola de nuevo. Al final se ha modificado la funcion para que solo tenga parametros de entrada (plsql no permite parametros de salida para funciones).
Ejecuto la sentencia: declare ret number; begin ret := null; ret := nombre_funcion (); dbms_output.put_line('ret = ' || to_char(ret)); end; esto me muestra el resultado que yo espero, sin embargo no me lo muestra cuando hago desde codigo: select nombre_funcion() from dual (en ambos casos utilizo los mismos parametros). Nota: dentro de la funcion se hace un insert en una tabla, el primer caso lo hace bien por eso me devuelve lo que esperaba pero la segunda forma no hace bien el insert y por eso me devuelve una excepcion. a q puede ser debido esto? (Si intento hacer el insert a secas tambien me lo permite pero desde la funcion cuando utilizo la forma "select funcion() from dual" no). Gracias pos su ayuda, un saludo. |
#16
|
|||
|
|||
Bueno finalmente os comento como lo he solucionado.
Lo primero decir que las unicas funciones que se pueden llamar de la forma: Select nombrefuncion() FROM dual, son las funciones que ya vienen compiladas como AVG,SUM,MAX,sysdate... pero las funciones externas que crea el usuario no. Por lo tanto ante la dificultad de recoger la salida de la funcion he optado por cambiar las funciones por procedimientos almacenados, mucho mas sencillos de tratar gracias al componente TADOStoredProc. Aqui tb se me ha planteado otro problema ya que la asignacion del nombre del procedimiento la hago en tiempo de ejecución por lo que los parámetros de entrada no se generan automáticamente como me comentaba jachgyate y hay q crearlos desde codigo. Espero que a alguien le sirva de algo la explicación.Si alguien quiere algun trozo de codigo solo tiene que pedirlo. Un saludo |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Llamada a Procedimiento Almacenado desde dentro de un Thread | MontarazAE | MS SQL Server | 2 | 29-05-2007 17:46:34 |
Problema con la llamada a un Procedimiento almacenado | Choclito | Firebird e Interbase | 3 | 06-12-2005 19:00:27 |
Ayuda, como llamar a un procedimiento desde otro procedimiento? | Ariatna | Varios | 1 | 01-02-2005 04:05:35 |
LLamada a un Procedimiento de un Paquete de Oracle | samuvk | JAVA | 11 | 18-05-2004 13:04:36 |
Insertar un array en un procedimiento de Oracle con JDBC | samuvk | JAVA | 2 | 17-05-2004 17:59:48 |
|