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 Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 18-09-2003
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 24
__cadetill Va por buen camino
Pasar nombre de tabla en SP

Hola

estoy intentando hacer un SP en el que quiero pasar por parámetro el nombre de una tabla a la que tengo que hacer una select. Tendría que ser algo así más o menos

Código:
CREATE PROCEDURE NUEVA_LINEA (
    TABLA VARCHAR(15))
RETURNS (
    COD_INT INTEGER)
AS
begin
  SELECT *
  FROM :TABLA
  INTO :cod_int;

  suspend;
end
pero no me compila (el error que lanza es el genérico de SQL). He probado de todo: poner comillas dobles, simples, son y sin los dos puntos,..... pero nada.

Cómo se puede hacer?
Responder Con Cita
  #2  
Antiguo 18-09-2003
Avatar de kinobi
kinobi kinobi is offline
Miembro
 
Registrado: may 2003
Posts: 2.621
Poder: 23
kinobi Va por buen camino
Hola,

Cita:
Posteado originalmente por cadetill
Cómo se puede hacer?
si es con Firebird 1.0.x (o inferiores) de ninguna forma, ya que el código que admiten procedimientos y desencadenadores no permite parametrizar objetos de la base de datos. En las versiones nuevas de InterBase lo desconozco.

Con la versión 1.5 de Firebird puedes intentarlo con la extensión "EXECUTE STATEMENT", como cometamos hace unas semanas ...

http://www.clubdelphi.com/foros/show...&threadid=2792

Saludos.
Responder Con Cita
  #3  
Antiguo 18-09-2003
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 24
__cadetill Va por buen camino
pues muchas gracias kinobi. Me instalare la RC6 a ver que resultados obtengo
Responder Con Cita
  #4  
Antiguo 19-09-2003
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 24
__cadetill Va por buen camino
bueno, y como muestra un botón

Código:
CREATE PROCEDURE NUEVA_LINEA (
    TABLA VARCHAR(15),
    CAMPO VARCHAR(15))
RETURNS (
    COD_INT INTEGER)
AS
begin
  EXECUTE STATEMENT 'SELECT MAX(' || :CAMPO || ') FROM ' || :TABLA INTO :COD_INT;

  if (:COD_INT is NULL) then
    COD_INT = 1;

  suspend;
end
Utilizando FB RC6. Compilado y funcionando

Gracias
Responder Con Cita
  #5  
Antiguo 19-09-2003
Avatar de kinobi
kinobi kinobi is offline
Miembro
 
Registrado: may 2003
Posts: 2.621
Poder: 23
kinobi Va por buen camino
Cita:
Posteado originalmente por cadetill
Utilizando FB RC6. Compilado y funcionando
Me gusta. Esta nueva extensión va a dar mucho juego.

Saludos.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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 03:49:31.


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