Ver Mensaje Individual
  #2  
Antiguo 03-07-2003
Avatar de kinobi
kinobi kinobi is offline
Miembro
 
Registrado: may 2003
Posts: 2.621
Reputación: 26
kinobi Va por buen camino
Hola,

Cita:
Posteado originalmente por mlara
Si quisiera usar sursores sería necesario que lo hiciera con DSQL.
No necesariamente. El SQL estático también trabaja con cursores. Es más, desde DSQL no podrás declarar cursores explícitamente.

Por si pudiese ir tu duda por este camino, cuando lanzas una setencia SELECT, por ejemplo desde una aplicación Delphi por medio de un componente TQuery (o similares), ya estás usando cursores, aunque el componente (en el caso del BDE, a través del controlador SQL-Links InterBase) encapsula y oculta toda su gestión. Al fin y al cabo, el cursor es el mecanismo que tiene el servidor para devolver (al cliente) el conjunto resultado de filas que produce la consulta, provenga ésta de una sentencia dinámica o estática.

Cita:
Posteado originalmente por mlara
Cuándo uso DSQL?
Cuando creas sentencias SQL en tiempo de ejecución, por ejemplo cuando pasas sentencias SQL al servidor a través de componentes de acceso como BDE, IBX, DBX, ..., cuando lo haces embebiendo las sentencias SQL en lenguajes anfitriones que lo permitan (necesitas un preprocesador SQL para ese lenguaje). Entiende en ambos casos que hablamos de sentencias creadas en tiempo de ejecución, que se desconocen antes de cualquier proceso de compilación.

Cita:
Posteado originalmente por mlara
En la Referencia del Lenguaje dice que DSQL permite crear sentencias en tiempo de ejecución. Cómo?
Básicamente de dos formas:

1. a través de las funciones del API dedicadas al DSQL (Documentación de InterBase 6, volumen "Api Guide", capítulo "6.- Working with Dynamic SQL"), bien llamándolas directamente, o encapsuladas en métodos de componentes (BDE, IBX, DBX, componentes de acceso que te crees tú, ...).

2. mediante SQL embebido (Documentación de InterBase 6, volumen "Embebed SQL", capítulo "13.- Using Dynamic SQL"), aunque al final el preprocesador las traducirá por las correspondientes llamadas al API y estarás en el caso 1.

Cita:
Posteado originalmente por mlara
Ahora, la última pregunta. Puedo crear un SP con DSQL?
No, el código de un procedimiento almacenado se "compila" (a un lenguaje denominado BLR) en el momento de su creación o actualización en la base de datos, por tanto, no admite la creación de sentencias al vuelo.

Saludos.

Última edición por kinobi fecha: 03-07-2003 a las 01:51:25.
Responder Con Cita