Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
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 15-09-2006
rafita rafita is offline
Miembro
 
Registrado: ago 2003
Ubicación: Cuenca- España.
Posts: 309
Poder: 21
rafita Va por buen camino
Saber si una consulta no devuelve datos

Hola otra vez, y con el mismo problema (prácticamente).

Es una pequeña aplicación mia, hecha con Delphi 5 contra Interbase 6.5 utilizando la BDE y corriendo en un Windows 2000 server.

Siempre he comprobado si una consulta devolvía datos utilizando el RecordCount>0, y la aplicación ha funcionado varios años (4 días al año) sin dar ningún problema.

Este año he tenido que añadirle (ahora con Delphi7) un par de formularios nuevos y, al hacer las pruebas, he visto que en algunas ocasiones la consulta devolvía datos y la variable RecordCound valía -1, mientras que en otras ocasiones sí funcionaba correctamente.

El problema lo solucioné cambiando el RecordCount por IsEmpty, pero me surge la duda de si fiarme o no del resto del código.
¿pensaís que en algún momento me fallará?
__________________
Rafita.
Responder Con Cita
  #2  
Antiguo 15-09-2006
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.037
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por rafita
Hola otra vez, y con el mismo problema (prácticamente).

Es una pequeña aplicación mia, hecha con Delphi 5 contra Interbase 6.5 utilizando la BDE y corriendo en un Windows 2000 server.

Siempre he comprobado si una consulta devolvía datos utilizando el RecordCount>0, y la aplicación ha funcionado varios años (4 días al año) sin dar ningún problema.

Este año he tenido que añadirle (ahora con Delphi7) un par de formularios nuevos y, al hacer las pruebas, he visto que en algunas ocasiones la consulta devolvía datos y la variable RecordCound valía -1, mientras que en otras ocasiones sí funcionaba correctamente.

El problema lo solucioné cambiando el RecordCount por IsEmpty, pero me surge la duda de si fiarme o no del resto del código.
¿pensaís que en algún momento me fallará?
Ley de Moorphy:
Si algo puede fallar... fallará.

Edito: Ya en serio, debe funcionar bien, aunque nunca usé el BDE salvo para pruebas.

Última edición por Casimiro Notevi fecha: 15-09-2006 a las 13:26:50.
Responder Con Cita
  #3  
Antiguo 15-09-2006
rafita rafita is offline
Miembro
 
Registrado: ago 2003
Ubicación: Cuenca- España.
Posts: 309
Poder: 21
rafita Va por buen camino
Gracias compañero por la respuesta.

Me quedo con la recomendación final.... aunque lo de la Ley de Moorphy me parece más acertado: FALLARÁ, seguro que fallará.

ta'luego
__________________
Rafita.
Responder Con Cita
  #4  
Antiguo 15-09-2006
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
Debería funcionar...
en algunas ocasiones, (no se exactamente en cuales), el recordcount no devolvía valor alguno hasta que no se hubiera recorrido el recordset por completo, es decir, tienes que ir al último registro y luego regresar al primero para que el valor de RecordCount se actualize.

IsEmpty debería funcionar correctamente, así como la comprobación de EoF = BoF.
__________________

Responder Con Cita
  #5  
Antiguo 18-09-2006
rafita rafita is offline
Miembro
 
Registrado: ago 2003
Ubicación: Cuenca- España.
Posts: 309
Poder: 21
rafita Va por buen camino
Este fin de semana me ha servido para reflexionar: si algo puede fallar, ... fallará.
Entonces... ¿dónde queda la exactitud de la informática? ¿2+2 son 4 o depende? ¿de qué depende?

Ahora me quedo con la respuesta de ContraVeneno: utilizar IsEmpty. Creo que merece la pena hacer los cambios y tener la seguridad de que no va a fallar.

Gracias a todos.
__________________
Rafita.
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Saber cuando termina una consulta zurech MySQL 2 16-09-2005 17:51:06
Saber Datos de Trigger lucasarts_18 MS SQL Server 2 06-09-2005 23:16:18
Saber cuantos registros origino la consulta JorgeBec SQL 1 12-11-2004 16:48:17
Limitar los registros que devuelve una consulta roman Conexión con bases de datos 1 03-09-2004 09:08:45
Quiero saber como agregar una consulta de SQL a un combobox Julio César Varios 4 15-01-2004 13:47:44


La franja horaria es GMT +2. Ahora son las 15:43:10.


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