Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Firebird e Interbase (https://www.clubdelphi.com/foros/forumdisplay.php?f=19)
-   -   Pasar nombre de tabla en SP (https://www.clubdelphi.com/foros/showthread.php?t=3747)

__cadetill 18-09-2003 17:59:17

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?

kinobi 18-09-2003 18:48:54

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.

__cadetill 18-09-2003 19:01:37

pues muchas gracias kinobi. Me instalare la RC6 a ver que resultados obtengo :)

__cadetill 19-09-2003 18:36:13

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 :D

Gracias

kinobi 19-09-2003 19:48:00

Cita:

Posteado originalmente por cadetill
Utilizando FB RC6. Compilado y funcionando
Me gusta. Esta nueva extensión va a dar mucho juego.

Saludos.


La franja horaria es GMT +2. Ahora son las 22:00:58.

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