Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-04-2012
Darkdrak Darkdrak is offline
Miembro
NULL
 
Registrado: mar 2012
Posts: 11
Poder: 0
Darkdrak Va por buen camino
Consulta sobre el uso de Stored Procedure en InterBase

Hola estoy muy metido cambiando el código para pasar todo de ADO a IB. Ahora tengo un problemita con el uso de los IBStoredProcedure.

A ver si alguien me puede corregir en que me equivoco.
////////////////////////////////////////////////////////////
Código Delphi [-]
with IBStoredProcedure do


 begin


 close;

 Params.Clear;

 Prepare;

 ParamByName('ID').Value := StrToInt (Edit1.Text);


 ExecProc;


 end;
////////////////////////////////////////////////////////////

Bueno eso anda de 10, pero en otro procedimiento si quiero hacer : IBStoredProcedure.First;

me dice que no se puede realizar la operación en una base de datos cerrada; el tema que si le doy Open o Active := true; me indica otro error
..."use execproc for procedure ..." debo tener un error de concepto en el uso de las stored procedures.

Desde ya gracias.
Responder Con Cita
  #2  
Antiguo 02-04-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Mira si este tutorial de Caral te aclara tus dudas.
Responder Con Cita
  #3  
Antiguo 02-04-2012
Darkdrak Darkdrak is offline
Miembro
NULL
 
Registrado: mar 2012
Posts: 11
Poder: 0
Darkdrak Va por buen camino
Ya lo vi

Gracias por contestar tan rápido, es una guía muy buena pero emplea IBQuerys, y yo estoy empleando IBStoredProcedures. El problema es al tratar de ejecutar el comando first, como ya explique.
Responder Con Cita
  #4  
Antiguo 02-04-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
El caso es que no somos adivinos para saber al menos lo que has puesto en ese procedure
Responder Con Cita
  #5  
Antiguo 02-04-2012
Darkdrak Darkdrak is offline
Miembro
NULL
 
Registrado: mar 2012
Posts: 11
Poder: 0
Darkdrak Va por buen camino
Ahora lo explico

Caso 1:

Código Delphi [-]
with IBStoredProcedure do


 begin

 close;

 Params.Clear;

 Prepare;

 ParamByName('ID').Value := StrToInt (Edit1.Text);


 ExecProc;

 First;


 end;

Aquí el error es que no se puede realizar la operación sobre una tabla cerrada.

Caso 2:

Código Delphi [-]
with IBStoredProcedure do


 begin

 close;

 Params.Clear;

 Prepare;

 ParamByName('ID').Value := StrToInt (Edit1.Text);


 ExecProc;

 open;

 end;

Aquí el error es "EIBClientError with message 'use ExecProc for Procedure; use TQuery for Select procedures' "'

Bueno aclaro que probe todo sin usar el with; y en vez de usar close y open; el Active true/false.

En fin, recurrí a varias opciones, estoy seguro que me equivoco en el uso de la IBStoredProcedure.

A ver si se entendió. Sino me puedo explayar más. Gracias otra vez.
Responder Con Cita
  #6  
Antiguo 02-04-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Sí, ¿pero el procedimiento almacenado qué hace?
Responder Con Cita
  #7  
Antiguo 02-04-2012
Darkdrak Darkdrak is offline
Miembro
NULL
 
Registrado: mar 2012
Posts: 11
Poder: 0
Darkdrak Va por buen camino
Contenido Stored Procedure

Acá esta el contenido del Procedure

Código SQL [-]
BEGIN
  /* Procedure body */  
  for
  select Q.*, CxL.NCultivo, CxL.ColorC
  
  from QGRILLALOTES (:IdCampoIn) Q
  
  left join  CampXLotes CxL on (CxL.IdLote = Q.IdLote )
  
  into :Idlote, :Nombre, :NCultivo, :ColorC
  
  do begin suspend; end 
   
  SUSPEND;
END

No pensé que tendría problemas aquí, ya que cuando usaba ADO en lugar de IB esto funcionaba bien. QGrillaLotes es otro procedure
Responder Con Cita
  #8  
Antiguo 02-04-2012
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 28
Lepe Va por buen camino
cuando uses "suspend" en el procedimiento almacenado, tienes que usar un IBQuery, porque se trata de procedimiento de selección.

Cuando no uses "suspend", o únicamente realices tareas de acción "delete from tabla", "insert" "update", entonces usas el IBStoreProc.


Incluso, si adoras los IbQuerys, también puedes usar un IBQuery con "execute procedure Miproc(:parametro1)" en el SQL.

Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #9  
Antiguo 02-04-2012
Darkdrak Darkdrak is offline
Miembro
NULL
 
Registrado: mar 2012
Posts: 11
Poder: 0
Darkdrak Va por buen camino
Gracias

A ver si lo entendí bien. Si modifico el Stored Procedure, sacando el suspend en el caso de una consulta, debería funcionar?

Tengo que modificar algo en el código de delphi? Por ahora no lo pude hacer funcionar.

Dejo de usar los ib stored procedure y usar directamente ibquery?

Última edición por Darkdrak fecha: 02-04-2012 a las 22:00:37.
Responder Con Cita
  #10  
Antiguo 04-04-2012
Avatar de defcon1_es
defcon1_es defcon1_es is offline
Miembro
 
Registrado: mar 2004
Ubicación: Cuenca - España
Posts: 533
Poder: 21
defcon1_es Va por buen camino
Cita:
Empezado por Darkdrak Ver Mensaje
Dejo de usar los ib stored procedure y usar directamente ibquery?
Creo recordar que el componente IBStoredProc no permite "navegar", se ejecuta y devuelve 1 sólo resultado en los parámetros del tipo ptOutput y ptInputOutput (salida)
Por eso, como bien te ha dicho Lepe, tienes que usar un IBQuery, porque se trata de procedimiento de selección que devuelve varias filas.

Código SQL [-]
Select Idlote, Nombre, NCultivo, ColorC
from MiProcedimientoAlmacenado (:ID)

Edito: He vuelto a leer los post de este hilo y el mensaje es MUY claro:
"EIBClientError with message 'use ExecProc for Procedure; use TQuery for Select procedures' "'
__________________
Progress Openedge
https://abevoelker.com/progress_open...dered_harmful/


Delphi forever...
Responder Con Cita
  #11  
Antiguo 06-04-2012
Darkdrak Darkdrak is offline
Miembro
NULL
 
Registrado: mar 2012
Posts: 11
Poder: 0
Darkdrak Va por buen camino
Finito...

Muchas gracias por las explicaciones. Osea que los IB stored procedures los podemos usar sobre todo para los procesos para agregar, modificar y eliminar registros de la tabla, y para las consultas devolviendo múltiples valores empleando los IB Query. Algo que descubrí; el parámetro se pasa por ParamByName, y FieldByName para acceder a los campos que devuelven los querys.

Sin más gracias a todos, una vez más.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Stored Procedure !!! Ledian_Fdez C++ Builder 0 02-03-2010 14:01:29
Error en Stored Procedure en InterBase gluglu Conexión con bases de datos 4 15-03-2005 10:05:55
Ver los Stored Procedure tgsistemas SQL 0 06-04-2004 17:18:22
Stored Procedure tgsistemas SQL 1 27-02-2004 13:10:33
Consulta Selectiva sobre Store Procedure raul_sal SQL 5 19-07-2003 21:35:37


La franja horaria es GMT +2. Ahora son las 06:51:33.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi