![]() |
Usando variables
Hace tiempo me resolvisteis una duda que tenía sobre como usar variables en un query. Me hace falta volver a usar esa metodología.
Tengo esta tabla: ![]() y sobre la misma ejecuto este query: y el resultado que me da es este: ![]() La realidad es que debería darme sólo la segunda línea. ¿Por qué me da dos filas en vez de una sola? Y es que el problema viene porque si trato de usar esa variable en el query en el que de verdad me hace falta: Me hace esto ![]() Que, evidentemente, no es lo que busco porque no me devuelve el valor de la variable definida. Aunque, curiosamente, el CASE del query sí va por el lado adecuado. No lo entiendo. |
El problema es que estás usando RDB$SET_CONTEXT dentro de un SELECT que devuelve varias filas, por lo que la función se ejecuta una vez por cada fila.
En Firebird estas funciones no son “variables globales” sino que se evalúan por fila. Si quieres que se ejecute una sola vez, usa FROM RDB$DATABASE, o mejor aún, evita SET_CONTEXT y usa una subconsulta o CTE. Te copio respuesta del primo chatgpt: ![]() |
Muchas gracias por las sugerencias. La que pones como opción 2 es la que estaba usando, pero me hace falta reutilizar el valor.
Sin embargo al probar la tercera opción que me das me genera un error: Cita:
|
Y la opción 1 efectivamente devuelve un única fila, pero con todos los valores a cero.
|
¿Será así?
|
Así es como lo tenía. Tendré que ver como apaño el resultado para usarlo. No sé si no estaré dando vueltas sin sentido. Gracias.
|
| La franja horaria es GMT +2. Ahora son las 02:11:42. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi