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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 14-03-2023
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Error al ejecutar una vista

A ver si consigo explicarme.
Tengo una vista definida en una BB.DD. en la que uso variables definidas dentro de ella. Me he dado cuenta que tal como estaba diseñada la vista los resultados no eran correctos y estoy tratando de modificarla. las definiciones actuales son estas:
Código SQL [-]
  • RDB$SET_CONTEXT('USER_TRANSACTION', 'AFILIADOS', (SELECT COUNT(*) FROM Persona WHERE CodPrv = A.CodPrv AND Junta = A.Codigo AND Situacion IN (SELECT Valor FROM Instalacion WHERE Etiqueta = 'Situacion' AND Situacion = 1)))
  • RDB$SET_CONTEXT('USER_TRANSACTION', 'HABITANTES', (SELECT Padron FROM HisElec WHERE CodPrv = A.CodPrv AND Municipio = A.Municipio AND Proceso = (SELECT MAX(Codigo) FROM Elecciones WHERE CodPrv = A.CodPrv)))
y las uso así:
Código SQL [-]
  • CAST(RDB$GET_CONTEXT('USER_TRANSACTION', 'AFILIADOS') AS INTEGER)
  • CASE WHEN RDB$GET_CONTEXT('USER_TRANSACTION', 'HABITANTES') = 0 THEN 0 ELSE 100 * CAST(RDB$GET_CONTEXT(' USER_TRANSACTION', 'AFILIADOS') AS NUMERIC(10, 2)) / CAST(RDB$GET_CONTEXT('USER_TRANSACTION', 'HABITANTES') AS NUMERIC(10, 2)) END
Si ejecuto la vista tal como están ahora definidas las variables no me da ningún error, pero no saca los datos que debe. En la definición de la primera variable (AFILIADOS) es donde me he dado cuenta que he cometido el error; si reemplazo la parte del código incorrecto y lo dejo así:
Código SQL [-]
RDB$SET_CONTEXT('USER_TRANSACTION', 'AFILIADOS', 
(SELECT COUNT(*) FROM Persona WHERE CodPrv = A.CodPrv 
AND Poblacion = (SELECT Municipio FROM Junta WHERE CodPrv = A.CodPrv AND Codigo = A.Codigo)
AND Situacion IN (SELECT Valor FROM Instalacion WHERE Etiqueta = 'Situacion' AND Situacion = 1)))
Al ejecutar el query sobre la vista me da este error:
Cita:
execution caused by system error that does not preclude successful execution of subsequent statements.
Invalid namespace name USER_TRANSACTION passed to RDB$GET_CONTEXT.

SQL Code: -901
IB Error Number: 335544844
y me he dado cuenta que si elimino el segundo RDB$GET_CONTEXT, entonces no se produce es error.

Última edición por Neftali [Germán.Estévez] fecha: 14-03-2023 a las 16:02:04. Razón: Saltos de línea para mejor lectura
Responder Con Cita
  #2  
Antiguo 23-03-2023
Avatar de Ñuño Martínez
Ñuño Martínez Ñuño Martínez is offline
Moderador
 
Registrado: jul 2006
Ubicación: Ciudad Catedral, Españistán
Posts: 6.000
Poder: 25
Ñuño Martínez Tiene un aura espectacularÑuño Martínez Tiene un aura espectacular
La verdad es que no tengo ni idea porque hace mucho que no trabajo con vistas en Delphi, pero contesto para que el mensaje suba de nuevo a la primera posición a ver si alguien que sepa lo ve y te ayuda.
__________________
Proyectos actuales --> Allegro 5 Pascal ¡y Delphi!|MinGRo Game Engine
Responder Con Cita
  #3  
Antiguo 24-03-2023
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Gracias. No creo que el problema tenga que ver con el entorno de trabajo; más bien parece un problema del motor.
Responder Con Cita
Respuesta



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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Firebird: Ejecutar programa en RED con winServer2008 y Vista JordiP Firebird e Interbase 1 27-07-2010 15:29:03
Ejecutar Excel en Vista acertij022 Varios 2 06-06-2008 15:40:21
Problema Al Ejecutar Aplicacion en Win Vista cjsp Windows 1 22-05-2007 04:38:14
Es posible ejecutar Windows Vista en tu PC ? gluglu Noticias 6 05-02-2007 14:41:34
Ejecutar SP en Vista cso2000 MS SQL Server 5 10-02-2005 00:29:57


La franja horaria es GMT +2. Ahora son las 16:57:29.


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