Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

 
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-07-2003
Avatar de mlara
[mlara] mlara is offline
Miembro Premium
 
Registrado: jun 2003
Ubicación: Colombia
Posts: 667
Poder: 21
mlara Va por buen camino
Cursores en iSQL

Bueno amigos, aquí tengo para ustedes este pequeño problema:

En un SP (procedimiento almacenado) quiero declarar algunos cursores dependiendo de alguna condición, así:

IF (fe_idcode = 'NA') THEN BEGIN
IF (subgroup <> '0000000000') THEN BEGIN
IF (SUBSTR(includes,4,4) = '0') THEN
DECLARE cursormaster CURSOR FOR
SELECT "IdCode"
FROM "PayMaster" WHERE "ET" = SUBSTR(:includes, 4, 4);
ELSE
DECLARE cursormaster CURSOR FOR
SELECT "IdCode"
FROM "PayMaster" WHERE "InstDep" = :instdep;
...
...

resulta que en la Referencia del Lenguaje dice que la sentencia DECLARE CURSOR está disponible para gpre y DSQL. Esto implica que al tratar de almacenar el SP a través de la ventana para iSQL (SQL interactivo) de IBConsole se genera un error.

Claro, entonces en vez de usar sentencias DECLARE CURSOR, uso sentencias FOR SELECT. Resulta que esto no sirve porque al usar FOR SELECT de inmediato estoy iniciando un bucle, lo cual no sucede cuando uso DECLARE CURSOR y luego avanzo a través del cursor cuando lo necesito mediante NEXT FETCH.

En el código de ejemplo se muestra claramente que la declaración de cursores no implica el inicio de bucles, y es algo esencial en el desarrollo que estoy haciendo.

Alguien podría decirme como puedo usar de otra forma cursores dentro de un SP, que no sea con FOR SELECT?

Muchas gracias.
__________________
...y mañana caminaré por las calles pasando inadvertido, como siempre.
Responder Con Cita
 



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


La franja horaria es GMT +2. Ahora son las 16:02:18.


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